From b83556fc6f478a3a5d1dd76cd305c52bcb08de2b Mon Sep 17 00:00:00 2001 From: adelikat Date: Tue, 15 Dec 2020 16:00:48 -0600 Subject: [PATCH] make fields readonly where possible --- .../Sound/Utilities/BufferedAsync.cs | 2 +- .../controllers/AutofireController.cs | 2 +- src/BizHawk.Common/DeepEquality.cs | 2 +- src/BizHawk.Common/Log.cs | 2 +- .../Database/Database.cs | 4 +- .../Arcades/MAME/MAME.cs | 20 +++---- .../CPUs/CP1610/CP1610.cs | 2 +- .../CPUs/Intel8048/Disassembler.cs | 2 +- .../CPUs/LR35902/Interrupts.cs | 2 +- .../CPUs/LR35902/NewDisassembler.cs | 2 +- .../CPUs/MC6800/Disassembler.cs | 2 +- .../CPUs/MC6809/Disassembler.cs | 6 +- .../CPUs/MOS 6502X/Execute.cs | 2 +- .../CPUs/W65816/Disassembler.cs | 2 +- .../AmstradCPC/AmstradCPC.ISettable.cs | 2 +- .../AmstradCPC/Hardware/Disk/NECUPD765.FDD.cs | 4 +- .../Hardware/Disk/NECUPD765.IPortIODevice.cs | 2 +- .../Hardware/Display/AmstradGateArray.cs | 8 +-- .../AmstradCPC/Hardware/Display/CRCT_6845.cs | 4 +- .../AmstradCPC/Hardware/Display/CRTDevice.cs | 4 +- .../AmstradCPC/Hardware/PPI/PPI_8255.cs | 2 +- .../Hardware/SoundOutput/AY38912.cs | 8 +-- .../AmstradCPC/Hardware/SoundOutput/Beeper.cs | 2 +- .../AmstradCPC/Machine/CPCBase.Input.cs | 30 +++++----- .../AmstradCPC/Machine/GateArrayBase.cs | 6 +- .../AmstradCPC/Media/Tape/CDT/CdtConverter.cs | 6 +- .../Computers/AppleII/AppleII.cs | 2 +- .../Components/EmptyPeripheralComponent.cs | 2 +- .../Commodore64/Cartridge/Mapper0020.cs | 4 +- .../Computers/Commodore64/MOS/Vic.Sprite.cs | 2 +- .../Computers/MSX/MSX.cs | 10 ++-- .../Hardware/Disk/NECUPD765.FDD.cs | 4 +- .../Hardware/Disk/NECUPD765.IPortIODevice.cs | 2 +- .../Hardware/Input/CursorJoystick.cs | 4 +- .../Hardware/Input/SinclairJoystick1.cs | 4 +- .../Hardware/Input/SinclairJoystick2.cs | 4 +- .../Hardware/SoundOuput/AY38912.cs | 8 +-- .../SinclairSpectrum/Machine/CPUMonitor.cs | 4 +- .../Machine/SpectrumBase.Input.cs | 30 +++++----- .../Computers/SinclairSpectrum/Machine/ULA.cs | 2 +- .../Media/Snapshot/SZX/SZX.Methods.cs | 2 +- .../Media/Tape/CSW/CswConverter.cs | 4 +- .../Media/Tape/PZX/PzxConverter.cs | 4 +- .../Media/Tape/TAP/TapConverter.cs | 4 +- .../Media/Tape/TZX/TzxConverter.cs | 6 +- .../Media/Tape/WAV/WavConverter.cs | 4 +- .../Media/Tape/WAV/WavStreamReader.cs | 4 +- .../SinclairSpectrum/ZXSpectrum.ISettable.cs | 2 +- .../Computers/SinclairSpectrum/ZXSpectrum.cs | 4 +- .../Consoles/Atari/2600/Tia/TIA.cs | 2 +- .../Consoles/Atari/A7800Hawk/Maria.cs | 2 +- .../Consoles/Belogic/Uzem.cs | 2 +- .../Consoles/Fairchild/ChannelF/Audio.cs | 4 +- .../Fairchild/ChannelF/ChannelF.IEmulator.cs | 4 +- .../Consoles/Fairchild/ChannelF/Video.cs | 2 +- .../Controllers/IntellivisionControllers.cs | 6 +- .../Consoles/Intellivision/STIC.cs | 2 +- .../Consoles/Nintendo/GBHawk/GBHawk.cs | 4 +- .../Gameboy/GambatteLink.IInputPollable.cs | 2 +- .../Gameboy/GambatteLink.IStatable.cs | 2 +- .../Nintendo/Gameboy/GambattePrinter.cs | 8 +-- .../Consoles/Nintendo/Gameboy/Sameboy.cs | 8 +-- .../Nintendo/N64/N64.IMemoryDomains.cs | 2 +- .../Consoles/Nintendo/N64/N64.IStatable.cs | 2 +- .../Consoles/Nintendo/N64/N64.cs | 4 +- .../Consoles/Nintendo/N64/N64Audio.cs | 2 +- .../Consoles/Nintendo/N64/N64VideoProvider.cs | 2 +- .../N64/NativeApi/mupen64plusAudioApi.cs | 6 +- .../N64/NativeApi/mupen64plusCoreApi.cs | 9 +-- .../N64/NativeApi/mupen64plusInputApi.cs | 6 +- .../N64/NativeApi/mupen64plusVideoApi.cs | 5 +- .../Consoles/Nintendo/NES/APU.cs | 36 ++++++------ .../Nintendo/NES/Boards/BANDAI-FCG-1.cs | 2 +- .../Consoles/Nintendo/NES/Boards/GameGenie.cs | 2 +- .../NES/Boards/MMC3_family/Mapper114.cs | 2 +- .../NES/Boards/MMC3_family/Mapper123.cs | 2 +- .../NES/Boards/MMC3_family/Mapper182.cs | 6 +- .../NES/Boards/MMC3_family/Mapper215.cs | 2 +- .../NES/Boards/MMC3_family/Mapper217.cs | 2 +- .../NES/Boards/MMC3_family/Pocahontas.cs | 2 +- .../Consoles/Nintendo/NES/Boards/Mapper043.cs | 2 +- .../Consoles/Nintendo/NES/Boards/Mapper116.cs | 2 +- .../Consoles/Nintendo/NES/Boards/Mapper156.cs | 2 +- .../Consoles/Nintendo/NES/Boards/Mapper244.cs | 4 +- .../Consoles/Nintendo/NES/Boards/NSFBoard.cs | 6 +- .../Nintendo/NES/Boards/Namcot129_163.cs | 2 +- .../NES/Boards/Namcot1xx/Namco163Audio.cs | 2 +- .../NES/Boards/Namcot1xx/Namcot1xx.cs | 2 +- .../Nintendo/NES/Boards/PxROM_FxROM.cs | 2 +- .../Consoles/Nintendo/NES/Boards/SEEPROM.cs | 2 +- .../Nintendo/NES/Boards/TENGEN-800032.cs | 16 +++--- .../Nintendo/NES/Boards/Taito_X1_017.cs | 2 +- .../NES/Boards/UNIF/UNIF_BMC-D1038.cs | 2 +- .../NES/Boards/UNIF/UNIF_BMC-GS-2013.cs | 8 +-- .../NES/Boards/UNIF/UNIF_UNL_DripGame.cs | 2 +- .../Consoles/Nintendo/NES/Boards/VRC1.cs | 2 +- .../Consoles/Nintendo/NES/Boards/VRC2_4.cs | 2 +- .../Consoles/Nintendo/NES/Boards/VRC6.cs | 10 ++-- .../Consoles/Nintendo/NES/BootGodDB.cs | 8 +-- .../Consoles/Nintendo/NES/FDS/FDSAudio.cs | 2 +- .../Consoles/Nintendo/NES/FDS/FDSInspector.cs | 6 +- .../Consoles/Nintendo/NES/NES.BoardSystem.cs | 2 +- .../Consoles/Nintendo/NES/NES.Core.cs | 6 +- .../Consoles/Nintendo/NES/NES.cs | 8 +-- .../Consoles/Nintendo/NES/PPU.run.cs | 4 +- .../Consoles/Nintendo/NES/Palettes.cs | 6 +- .../Consoles/Nintendo/QuickNES/QuickNES.cs | 10 ++-- .../Consoles/Nintendo/SNES/LibsnesApi.cs | 6 +- .../Consoles/Nintendo/SNES/LibsnesCore.cs | 2 +- .../Nintendo/SNES/SNESGraphicsDecoder.cs | 14 ++--- .../Consoles/Nintendo/SNES/SnesColors.cs | 2 +- .../Consoles/Nintendo/SNES9X/Snes9x.cs | 2 +- .../Consoles/Nintendo/VB/VirtualBoyee.cs | 2 +- .../Consoles/PC Engine/PCEngine.cs | 2 +- .../Consoles/PC Engine/ScsiCDBus.cs | 6 +- .../Consoles/PC Engine/VPC.cs | 2 +- .../Consoles/Sega/PicoDrive/PicoDrive.cs | 10 ++-- .../Consoles/Sega/SMS/SMS.cs | 10 ++-- .../Consoles/Sega/SMS/VDP.ModeTMS.cs | 2 +- .../Consoles/Sega/SMS/VDP.cs | 10 ++-- .../Consoles/Sega/gpgx64/GPGX.IDebuggable.cs | 2 +- .../Consoles/Sega/gpgx64/GPGX.cs | 14 ++--- .../Consoles/Sega/gpgx64/GenDbgHlp.cs | 4 +- .../Consoles/Sony/PS2/DobieStation.cs | 2 +- .../Sony/PSX/Octoshock.IDebuggable.cs | 2 +- .../Consoles/Sony/PSX/Octoshock.cs | 10 ++-- .../WonderSwan/WonderSwan.IStatable.cs | 2 +- .../Consoles/WonderSwan/WonderSwan.cs | 2 +- src/BizHawk.Emulation.Cores/FileID.cs | 56 +++++++++---------- .../Libretro/LibretroApi.cs | 8 +-- .../Libretro/LibretroCore.cs | 2 +- .../Sound/DualSyncSound.cs | 8 +-- .../Sound/OneBitBeeper.cs | 2 +- .../Sound/SyncSoundMixer.cs | 2 +- src/BizHawk.Emulation.Cores/Sound/VRC6Alt.cs | 10 ++-- src/BizHawk.Emulation.Cores/Sound/YM2413.cs | 28 +++++----- .../Waterbox/NymaCore.Controller.cs | 2 +- .../NymaCore.Settings.ComponentModel.cs | 2 +- .../Waterbox/NymaCore.Settings.cs | 6 +- .../Waterbox/WaterboxCore.cs | 2 +- .../API_MednaDisc.cs | 2 +- .../CDFS/EndianBitConverter.cs | 2 +- .../CDFS/ISOVolumeDescriptor.cs | 4 +- .../DiscFormats/Blobs/Blob_WaveFile.cs | 2 +- .../DiscFormats/Blobs/Blob_ZeroPadAdapter.cs | 4 +- .../DiscFormats/CUE/CUE_Load.cs | 2 +- .../DiscFormats/CUE/CUE_Parse.cs | 2 +- .../DiscHasher.cs | 4 +- .../DiscSectorReader.cs | 8 +-- .../DiscStream.cs | 8 +-- 150 files changed, 392 insertions(+), 392 deletions(-) diff --git a/src/BizHawk.Client.Common/Sound/Utilities/BufferedAsync.cs b/src/BizHawk.Client.Common/Sound/Utilities/BufferedAsync.cs index 2972060f92..d3d54343ae 100644 --- a/src/BizHawk.Client.Common/Sound/Utilities/BufferedAsync.cs +++ b/src/BizHawk.Client.Common/Sound/Utilities/BufferedAsync.cs @@ -37,7 +37,7 @@ namespace BizHawk.Client.Common private readonly Queue buffer = new Queue(MaxExcessSamples); private int SamplesInOneFrame = 1470; - private int TargetExtraSamples = 882; + private readonly int TargetExtraSamples = 882; private const int MaxExcessSamples = 4096; /// diff --git a/src/BizHawk.Client.Common/controllers/AutofireController.cs b/src/BizHawk.Client.Common/controllers/AutofireController.cs index 9ae6a09ec5..1218cc65f7 100644 --- a/src/BizHawk.Client.Common/controllers/AutofireController.cs +++ b/src/BizHawk.Client.Common/controllers/AutofireController.cs @@ -22,7 +22,7 @@ namespace BizHawk.Client.Common private readonly WorkingDictionary _buttons = new WorkingDictionary(); private readonly WorkingDictionary _buttonStarts = new WorkingDictionary(); - private bool _autofire = true; + private readonly bool _autofire = true; public int On { get; set; } public int Off { get; set; } diff --git a/src/BizHawk.Common/DeepEquality.cs b/src/BizHawk.Common/DeepEquality.cs index b1decac1f2..aafd1808e8 100644 --- a/src/BizHawk.Common/DeepEquality.cs +++ b/src/BizHawk.Common/DeepEquality.cs @@ -49,7 +49,7 @@ namespace BizHawk.Common } } - private static MethodInfo ArrayEqualsGeneric = typeof(DeepEquality).GetMethod("ArrayEquals", BindingFlags.NonPublic | BindingFlags.Static); + private static readonly MethodInfo ArrayEqualsGeneric = typeof(DeepEquality).GetMethod("ArrayEquals", BindingFlags.NonPublic | BindingFlags.Static); /// test if two objects and are equal, field-by-field (with deep inspection of each field) /// is an array with rank > 1 or is a non-zero-indexed array diff --git a/src/BizHawk.Common/Log.cs b/src/BizHawk.Common/Log.cs index 8d9697f978..432d4e1c73 100644 --- a/src/BizHawk.Common/Log.cs +++ b/src/BizHawk.Common/Log.cs @@ -63,7 +63,7 @@ namespace BizHawk.Common public static Stream HACK_LOG_STREAM; private static readonly bool LogToConsole = false; - private static bool LogToFile = false; + private static readonly bool LogToFile = false; private const string LogFilename = "bizhawk.txt"; private static StreamWriter writer; diff --git a/src/BizHawk.Emulation.Common/Database/Database.cs b/src/BizHawk.Emulation.Common/Database/Database.cs index b65878e46a..6cbf49d36d 100644 --- a/src/BizHawk.Emulation.Common/Database/Database.cs +++ b/src/BizHawk.Emulation.Common/Database/Database.cs @@ -13,12 +13,12 @@ namespace BizHawk.Emulation.Common { public static class Database { - private static Dictionary DB = new Dictionary(); + private static readonly Dictionary DB = new Dictionary(); /// /// blocks until the DB is done loading /// - private static EventWaitHandle acquire = new EventWaitHandle(false, EventResetMode.ManualReset); + private static readonly EventWaitHandle acquire = new EventWaitHandle(false, EventResetMode.ManualReset); private static string RemoveHashType(string hash) { diff --git a/src/BizHawk.Emulation.Cores/Arcades/MAME/MAME.cs b/src/BizHawk.Emulation.Cores/Arcades/MAME/MAME.cs index e59cf1136c..a0dc3ee631 100644 --- a/src/BizHawk.Emulation.Cores/Arcades/MAME/MAME.cs +++ b/src/BizHawk.Emulation.Cores/Arcades/MAME/MAME.cs @@ -163,12 +163,12 @@ namespace BizHawk.Emulation.Cores.Arcades.MAME public IInputCallbackSystem InputCallbacks => throw new NotImplementedException(); private SyncSettings _syncSettings; - private Thread _mameThread; - private ManualResetEvent _mameStartupComplete = new ManualResetEvent(false); - private ManualResetEvent _mameFrameComplete = new ManualResetEvent(false); - private ManualResetEvent _memoryAccessComplete = new ManualResetEvent(false); - private AutoResetEvent _mamePeriodicComplete = new AutoResetEvent(false); - private SortedDictionary _fieldsPorts = new SortedDictionary(); + private readonly Thread _mameThread; + private readonly ManualResetEvent _mameStartupComplete = new ManualResetEvent(false); + private readonly ManualResetEvent _mameFrameComplete = new ManualResetEvent(false); + private readonly ManualResetEvent _memoryAccessComplete = new ManualResetEvent(false); + private readonly AutoResetEvent _mamePeriodicComplete = new AutoResetEvent(false); + private readonly SortedDictionary _fieldsPorts = new SortedDictionary(); private SortedDictionary _romHashes = new SortedDictionary(); private IController _controller = NullController.Instance; private IMemoryDomains _memoryDomains; @@ -177,15 +177,15 @@ namespace BizHawk.Emulation.Cores.Arcades.MAME private int _systemBusAddressShift = 0; private bool _memAccess = false; private int[] _frameBuffer = new int[0]; - private Queue _audioSamples = new Queue(); + private readonly Queue _audioSamples = new Queue(); private decimal _dAudioSamples = 0; - private int _sampleRate = 44100; + private readonly int _sampleRate = 44100; private int _numSamples = 0; private bool _paused = true; private bool _exiting = false; private bool _frameDone = true; - private string _gameDirectory; - private string _gameFilename; + private readonly string _gameDirectory; + private readonly string _gameFilename; private string _gameName = "Arcade"; private string _loadFailure = ""; private LibMAME.PeriodicCallbackDelegate _periodicCallback; diff --git a/src/BizHawk.Emulation.Cores/CPUs/CP1610/CP1610.cs b/src/BizHawk.Emulation.Cores/CPUs/CP1610/CP1610.cs index f8ae16592b..14c71ef2d2 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/CP1610/CP1610.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/CP1610/CP1610.cs @@ -60,7 +60,7 @@ namespace BizHawk.Emulation.Cores.Components.CP1610 public Func ReadMemory; public Func WriteMemory; - private static bool Logging = false; + private static readonly bool Logging = false; private static readonly StreamWriter Log; public void SyncState(Serializer ser) diff --git a/src/BizHawk.Emulation.Cores/CPUs/Intel8048/Disassembler.cs b/src/BizHawk.Emulation.Cores/CPUs/Intel8048/Disassembler.cs index 7930d0021c..6133d852e1 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/Intel8048/Disassembler.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/Intel8048/Disassembler.cs @@ -6,7 +6,7 @@ namespace BizHawk.Emulation.Cores.Components.I8048 { public sealed partial class I8048 { - static string[] table = + static readonly string[] table = { "NOP", // 00 "???", // 01 diff --git a/src/BizHawk.Emulation.Cores/CPUs/LR35902/Interrupts.cs b/src/BizHawk.Emulation.Cores/CPUs/LR35902/Interrupts.cs index 2ac651fa24..513870537f 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/LR35902/Interrupts.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/LR35902/Interrupts.cs @@ -56,7 +56,7 @@ namespace BizHawk.Emulation.Cores.Components.LR35902 OP }; } - private static ushort[] INT_vectors = { 0x40, 0x48, 0x50, 0x58, 0x60, 0x00 }; + private static readonly ushort[] INT_vectors = { 0x40, 0x48, 0x50, 0x58, 0x60, 0x00 }; public ushort int_src; public byte int_clear; diff --git a/src/BizHawk.Emulation.Cores/CPUs/LR35902/NewDisassembler.cs b/src/BizHawk.Emulation.Cores/CPUs/LR35902/NewDisassembler.cs index e745f3f552..80ecc85598 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/LR35902/NewDisassembler.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/LR35902/NewDisassembler.cs @@ -7,7 +7,7 @@ namespace BizHawk.Emulation.Cores.Components.LR35902 // adapted from the information at http://www.pastraiser.com/cpu/gameboy/gameboy_opcodes.html public sealed partial class LR35902 { - static string[] table = + static readonly string[] table = { "NOP", // 00 "LD BC,d16", // 01 diff --git a/src/BizHawk.Emulation.Cores/CPUs/MC6800/Disassembler.cs b/src/BizHawk.Emulation.Cores/CPUs/MC6800/Disassembler.cs index ae996f1bca..abc83e8545 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/MC6800/Disassembler.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/MC6800/Disassembler.cs @@ -6,7 +6,7 @@ namespace BizHawk.Emulation.Cores.Components.MC6800 { public sealed partial class MC6800 { - static string[] table = + static readonly string[] table = { "???", // 00 "NOP", // 01 diff --git a/src/BizHawk.Emulation.Cores/CPUs/MC6809/Disassembler.cs b/src/BizHawk.Emulation.Cores/CPUs/MC6809/Disassembler.cs index 9ec17084fe..a5cdc28a94 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/MC6809/Disassembler.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/MC6809/Disassembler.cs @@ -6,7 +6,7 @@ namespace BizHawk.Emulation.Cores.Components.MC6809 { public sealed partial class MC6809 { - static string[] table = + static readonly string[] table = { "NEG DP+i8", // 00 "???", // 01 @@ -266,7 +266,7 @@ namespace BizHawk.Emulation.Cores.Components.MC6809 "ST U,ex16", // ff }; - static string[] table2 = + static readonly string[] table2 = { "???", // 00 "???", // 01 @@ -526,7 +526,7 @@ namespace BizHawk.Emulation.Cores.Components.MC6809 "ST SP,ex16", // ff }; - static string[] table3 = + static readonly string[] table3 = { "???", // 00 "???", // 01 diff --git a/src/BizHawk.Emulation.Cores/CPUs/MOS 6502X/Execute.cs b/src/BizHawk.Emulation.Cores/CPUs/MOS 6502X/Execute.cs index 8678f222ca..ece32ca4ec 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/MOS 6502X/Execute.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/MOS 6502X/Execute.cs @@ -30,7 +30,7 @@ namespace BizHawk.Emulation.Cores.Components.M6502 // CompiledMicrocode[i] = (short)temp[i]; } - static Uop[][] Microcode = + static readonly Uop[][] Microcode = { //0x00 /*BRK [implied]*/ new Uop[] { Uop.Fetch2, Uop.PushPCH, Uop.PushPCL, Uop.PushP_BRK, Uop.FetchPCLVector, Uop.FetchPCHVector, Uop.End_SuppressInterrupt }, diff --git a/src/BizHawk.Emulation.Cores/CPUs/W65816/Disassembler.cs b/src/BizHawk.Emulation.Cores/CPUs/W65816/Disassembler.cs index 3c36f84a66..ece67bcb34 100644 --- a/src/BizHawk.Emulation.Cores/CPUs/W65816/Disassembler.cs +++ b/src/BizHawk.Emulation.Cores/CPUs/W65816/Disassembler.cs @@ -21,7 +21,7 @@ namespace BizHawk.Emulation.Cores.Components.W65816 { public string Cpu { get; set; } - W65816 disassemblerCpu = new W65816(); + readonly W65816 disassemblerCpu = new W65816(); public IEnumerable AvailableCpus { diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/AmstradCPC.ISettable.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/AmstradCPC.ISettable.cs index fac6bdeb5e..c67fcb9328 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/AmstradCPC.ISettable.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/AmstradCPC.ISettable.cs @@ -158,7 +158,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC public string Media { get; set; } public string OtherMisc { get; set; } - Dictionary Data = new Dictionary(); + readonly Dictionary Data = new Dictionary(); public static CPCMachineMetaData GetMetaObject(MachineType type) { diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.FDD.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.FDD.cs index c98ccaabc5..326992a5af 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.FDD.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.FDD.cs @@ -43,7 +43,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// Array that holds state information for each possible drive /// - private DriveState[] DriveStates = new DriveState[4]; + private readonly DriveState[] DriveStates = new DriveState[4]; /// /// Initialization / reset of the floppy drive subsystem @@ -283,7 +283,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// The parent controller /// - private NECUPD765 FDC; + private readonly NECUPD765 FDC; /// /// TRUE if we are on track 0 diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.IPortIODevice.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.IPortIODevice.cs index 64ff48a317..6c24e18716 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.IPortIODevice.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Disk/NECUPD765.IPortIODevice.cs @@ -36,7 +36,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC * MK flag * SK flag * */ - private string[] workingArr = new string[3]; + private readonly string[] workingArr = new string[3]; private void BuildCSVLine() { diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/AmstradGateArray.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/AmstradGateArray.cs index 7e746fbbb9..fb519369e1 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/AmstradGateArray.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/AmstradGateArray.cs @@ -16,7 +16,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// public class AmstradGateArray : IPortIODevice, IVideoProvider { - private CPCBase _machine; + private readonly CPCBase _machine; private Z80A CPU => _machine.CPU; private CRCT_6845 CRCT => _machine.CRCT; //private CRTDevice CRT => _machine.CRT; @@ -679,18 +679,18 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// The current character line we are working from /// - private CharacterLine CurrentLine; + private readonly CharacterLine CurrentLine; /// /// List of screen lines as they are built up /// - private List ScreenLines = new List(); + private readonly List ScreenLines = new List(); /// /// Pixel value lookups for every scanline byte value /// Based on the lookup at https://github.com/gavinpugh/xnacpc /// - private int[][] ByteLookup = new int[4][]; + private readonly int[][] ByteLookup = new int[4][]; private void InitByteLookup() { int pix; diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRCT_6845.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRCT_6845.cs index 8ea7367061..a84e66c9bd 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRCT_6845.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRCT_6845.cs @@ -364,14 +364,14 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// http://www.cantrell.org.uk/david/tech/cpc/cpc-firmware/firmware.pdf /// (The defaults values given here are those programmed by the firmware ROM after a cold/warm boot of the CPC/Plus) /// - private byte[] RegDefaults = { 63, 40, 46, 112, 38, 0, 25, 30, 0, 7, 0, 0, 48, 0, 192, 7, 0, 0 }; + private readonly byte[] RegDefaults = { 63, 40, 46, 112, 38, 0, 25, 30, 0, 7, 0, 0, 48, 0, 192, 7, 0, 0 }; /// /// Register masks /// 0 = WRITE /// 1 = READ /// - private byte[] CPCMask = { 255, 255, 255, 255, 127, 31, 127, 126, 3, 31, 31, 31, 63, 255, 63, 255, 63, 255 }; + private readonly byte[] CPCMask = { 255, 255, 255, 255, 127, 31, 127, 126, 3, 31, 31, 31, 63, 255, 63, 255, 63, 255 }; /// /// Horizontal Character Count diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRTDevice.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRTDevice.cs index fd350064c3..6399bad049 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRTDevice.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/Display/CRTDevice.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// public class CRTDevice : IVideoProvider { - private CPCBase _machine; + private readonly CPCBase _machine; private CRCT_6845 CRCT => _machine.CRCT; private AmstradGateArray GateArray => _machine.GateArray; @@ -250,7 +250,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// The calling CRT device /// - private CRTDevice CRT; + private readonly CRTDevice CRT; public ScanLine(CRTDevice crt) { diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/PPI/PPI_8255.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/PPI/PPI_8255.cs index 6a2b95aa02..535c111003 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/PPI/PPI_8255.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/PPI/PPI_8255.cs @@ -11,7 +11,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// public class PPI_8255 : IPortIODevice { - private CPCBase _machine; + private readonly CPCBase _machine; private CRCT_6845 CRTC => _machine.CRCT; private AmstradGateArray GateArray => _machine.GateArray; private IPSG PSG => _machine.AYDevice; diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/AY38912.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/AY38912.cs index 9ef5890804..396409ce5b 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/AY38912.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/AY38912.cs @@ -16,7 +16,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// The emulated machine (passed in via constructor) /// - private CPCBase _machine; + private readonly CPCBase _machine; private IKeyboard _keyboard => _machine.KeyboardDevice; private int _tStatesPerFrame; @@ -409,7 +409,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// The frequency of the AY chip /// - private static int _chipFrequency = 1000000; // 1773400; + private static readonly int _chipFrequency = 1000000; // 1773400; /// /// The rendering resolution of the chip @@ -504,7 +504,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// Panning table list /// - private static List PanTabs = new List + private static readonly List PanTabs = new List { // MONO new uint[] { 50,50, 50,50, 50,50 }, @@ -540,7 +540,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// Volume table to be used /// - private static uint[] AYVolumes = + private static readonly uint[] AYVolumes = { 0x0000,0x0000,0x0340,0x0340,0x04C0,0x04C0,0x06F2,0x06F2, 0x0A44,0x0A44,0x0F13,0x0F13,0x1510,0x1510,0x227E,0x227E, diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/Beeper.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/Beeper.cs index 6ec1c22067..204a2a21e8 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/Beeper.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Hardware/SoundOutput/Beeper.cs @@ -53,7 +53,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// The parent emulated machine /// - private CPCBase _machine; + private readonly CPCBase _machine; /// /// The last pulse diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/CPCBase.Input.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/CPCBase.Input.cs index fb43e7602b..99b85ae0b7 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/CPCBase.Input.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/CPCBase.Input.cs @@ -6,23 +6,23 @@ /// public abstract partial class CPCBase { - string Play = "Play Tape"; - string Stop = "Stop Tape"; - string RTZ = "RTZ Tape"; - string Record = "Record Tape"; - string NextTape = "Insert Next Tape"; - string PrevTape = "Insert Previous Tape"; - string NextBlock = "Next Tape Block"; - string PrevBlock = "Prev Tape Block"; - string TapeStatus = "Get Tape Status"; + readonly string Play = "Play Tape"; + readonly string Stop = "Stop Tape"; + readonly string RTZ = "RTZ Tape"; + readonly string Record = "Record Tape"; + readonly string NextTape = "Insert Next Tape"; + readonly string PrevTape = "Insert Previous Tape"; + readonly string NextBlock = "Next Tape Block"; + readonly string PrevBlock = "Prev Tape Block"; + readonly string TapeStatus = "Get Tape Status"; - string NextDisk = "Insert Next Disk"; - string PrevDisk = "Insert Previous Disk"; - string EjectDisk = "Eject Current Disk"; - string DiskStatus = "Get Disk Status"; + readonly string NextDisk = "Insert Next Disk"; + readonly string PrevDisk = "Insert Previous Disk"; + readonly string EjectDisk = "Eject Current Disk"; + readonly string DiskStatus = "Get Disk Status"; - string HardResetStr = "Power"; - string SoftResetStr = "Reset"; + readonly string HardResetStr = "Power"; + readonly string SoftResetStr = "Reset"; bool pressed_Play = false; bool pressed_Stop = false; diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/GateArrayBase.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/GateArrayBase.cs index 454bfaac69..71cf090839 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/GateArrayBase.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Machine/GateArrayBase.cs @@ -16,7 +16,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC public int Z80ClockSpeed = 4000000; public int FrameLength = 79872; - private CPCBase _machine; + private readonly CPCBase _machine; private Z80A CPU => _machine.CPU; private CRCT_6845 CRCT => _machine.CRCT; private IPSG PSG => _machine.AYDevice; @@ -190,13 +190,13 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC } } - private int[] PenColours; + private readonly int[] PenColours; private int CurrentPen; private int ScreenMode; private int INTScanlineCnt; //private int VSYNCDelyCnt; - private int[][] Lookup = new int[4][]; + private readonly int[][] Lookup = new int[4][]; //private bool DoModeUpdate; diff --git a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Media/Tape/CDT/CdtConverter.cs b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Media/Tape/CDT/CdtConverter.cs index ec6e98737c..43af3d3cea 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Media/Tape/CDT/CdtConverter.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AmstradCPC/Media/Tape/CDT/CdtConverter.cs @@ -13,7 +13,7 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// The type of serializer /// - private MediaConverterType _formatType = MediaConverterType.CDT; + private readonly MediaConverterType _formatType = MediaConverterType.CDT; public override MediaConverterType FormatType => _formatType; /// @@ -39,9 +39,9 @@ namespace BizHawk.Emulation.Cores.Computers.AmstradCPC /// /// Object to keep track of loops - this assumes there is only one loop at a time /// - private List> _loopCounter = new List>(); + private readonly List> _loopCounter = new List>(); - private DatacorderDevice _datacorder; + private readonly DatacorderDevice _datacorder; public CdtConverter(DatacorderDevice _tapeDevice) { diff --git a/src/BizHawk.Emulation.Cores/Computers/AppleII/AppleII.cs b/src/BizHawk.Emulation.Cores/Computers/AppleII/AppleII.cs index 45229b346e..baa029dc5d 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AppleII/AppleII.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AppleII/AppleII.cs @@ -59,7 +59,7 @@ namespace BizHawk.Emulation.Cores.Computers.AppleII private readonly List _romSet = new List(); private readonly ITraceable _tracer; - private Components _machine; + private readonly Components _machine; private byte[] _disk1; private readonly byte[] _appleIIRom; private readonly byte[] _diskIIRom; diff --git a/src/BizHawk.Emulation.Cores/Computers/AppleII/Components/EmptyPeripheralComponent.cs b/src/BizHawk.Emulation.Cores/Computers/AppleII/Components/EmptyPeripheralComponent.cs index 643fbdd3d6..a6db30224f 100644 --- a/src/BizHawk.Emulation.Cores/Computers/AppleII/Components/EmptyPeripheralComponent.cs +++ b/src/BizHawk.Emulation.Cores/Computers/AppleII/Components/EmptyPeripheralComponent.cs @@ -8,7 +8,7 @@ namespace BizHawk.Emulation.Cores.Computers.AppleII public class EmptyPeripheralCard : IPeripheralCard { // TODO: make readonly once json isn't used - private Video _video; + private readonly Video _video; // TODO: remove when json isn't used public EmptyPeripheralCard() { } diff --git a/src/BizHawk.Emulation.Cores/Computers/Commodore64/Cartridge/Mapper0020.cs b/src/BizHawk.Emulation.Cores/Computers/Commodore64/Cartridge/Mapper0020.cs index d720ad162d..a533063be2 100644 --- a/src/BizHawk.Emulation.Cores/Computers/Commodore64/Cartridge/Mapper0020.cs +++ b/src/BizHawk.Emulation.Cores/Computers/Commodore64/Cartridge/Mapper0020.cs @@ -26,8 +26,8 @@ namespace BizHawk.Emulation.Cores.Computers.Commodore64.Cartridge { private int _bankOffset = 63 << 13; - private int[] _banksA = new int[64 << 13]; // 8000 - private int[] _banksB = new int[64 << 13]; // A000 + private readonly int[] _banksA = new int[64 << 13]; // 8000 + private readonly int[] _banksB = new int[64 << 13]; // A000 private readonly int[] _originalMediaA; // 8000 private readonly int[] _originalMediaB; // A000 diff --git a/src/BizHawk.Emulation.Cores/Computers/Commodore64/MOS/Vic.Sprite.cs b/src/BizHawk.Emulation.Cores/Computers/Commodore64/MOS/Vic.Sprite.cs index 50b88516af..d5b4d090c0 100644 --- a/src/BizHawk.Emulation.Cores/Computers/Commodore64/MOS/Vic.Sprite.cs +++ b/src/BizHawk.Emulation.Cores/Computers/Commodore64/MOS/Vic.Sprite.cs @@ -12,7 +12,7 @@ namespace BizHawk.Emulation.Cores.Computers.Commodore64.MOS public bool Display; public bool Dma; public bool Enable; - public int Index; + public readonly int Index; public int Loaded; public int Mc; public int Mcbase; diff --git a/src/BizHawk.Emulation.Cores/Computers/MSX/MSX.cs b/src/BizHawk.Emulation.Cores/Computers/MSX/MSX.cs index e4f27f7063..cf1a02e41d 100644 --- a/src/BizHawk.Emulation.Cores/Computers/MSX/MSX.cs +++ b/src/BizHawk.Emulation.Cores/Computers/MSX/MSX.cs @@ -114,20 +114,20 @@ namespace BizHawk.Emulation.Cores.Computers.MSX // Machine resources private IController _controller = NullController.Instance; - private ControllerDefinition current_controller = null; + private readonly ControllerDefinition current_controller = null; private int _frame = 0; public DisplayType Region => DisplayType.NTSC; - private ITraceable Tracer; + private readonly ITraceable Tracer; private LibMSX.TraceCallback tracecb; // these will be constant values assigned during core construction private int Header_Length; - private int Disasm_Length; - private int Reg_String_Length; + private readonly int Disasm_Length; + private readonly int Reg_String_Length; private void MakeTrace(int t) { @@ -144,7 +144,7 @@ namespace BizHawk.Emulation.Cores.Computers.MSX }); } - private MemoryCallbackSystem _memorycallbacks = new MemoryCallbackSystem(new[] { "System Bus" }); + private readonly MemoryCallbackSystem _memorycallbacks = new MemoryCallbackSystem(new[] { "System Bus" }); public IMemoryCallbackSystem MemoryCallbacks => _memorycallbacks; } } diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.FDD.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.FDD.cs index 1a55ad668c..3912f22ba0 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.FDD.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.FDD.cs @@ -43,7 +43,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// Array that holds state information for each possible drive /// - private DriveState[] DriveStates = new DriveState[4]; + private readonly DriveState[] DriveStates = new DriveState[4]; /// /// Initialization / reset of the floppy drive subsystem @@ -283,7 +283,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The parent controller /// - private NECUPD765 FDC; + private readonly NECUPD765 FDC; /// /// TRUE if we are on track 0 diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.IPortIODevice.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.IPortIODevice.cs index 1dd082b7d0..77b6c44915 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.IPortIODevice.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Disk/NECUPD765.IPortIODevice.cs @@ -36,7 +36,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum * MK flag * SK flag * */ - private string[] workingArr = new string[3]; + private readonly string[] workingArr = new string[3]; private void BuildCSVLine() { diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/CursorJoystick.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/CursorJoystick.cs index 85e41fdcc3..66c7078896 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/CursorJoystick.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/CursorJoystick.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum public class CursorJoystick : IJoystick { //private int _joyLine; - private SpectrumBase _machine; + private readonly SpectrumBase _machine; public CursorJoystick(SpectrumBase machine, int playerNumber) { @@ -28,7 +28,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum }.ToArray(); } - private List btnLookups = new List + private readonly List btnLookups = new List { "Key 5", // left "Key 8", // right diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick1.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick1.cs index 713112c119..b16d024075 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick1.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick1.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum public class SinclairJoystick1 : IJoystick { //private int _joyLine; - private SpectrumBase _machine; + private readonly SpectrumBase _machine; public SinclairJoystick1(SpectrumBase machine, int playerNumber) { @@ -28,7 +28,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum }.ToArray(); } - private List btnLookups = new List + private readonly List btnLookups = new List { "Key 1", // left "Key 2", // right diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick2.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick2.cs index 572b11806a..d35504e9b0 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick2.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/Input/SinclairJoystick2.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum public class SinclairJoystick2 : IJoystick { //private int _joyLine; - private SpectrumBase _machine; + private readonly SpectrumBase _machine; public SinclairJoystick2(SpectrumBase machine, int playerNumber) { @@ -28,7 +28,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum }.ToArray(); } - private List btnLookups = new List + private readonly List btnLookups = new List { "Key 6", // left "Key 7", // right diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/SoundOuput/AY38912.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/SoundOuput/AY38912.cs index 5e97f797a6..70f6f17fc4 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/SoundOuput/AY38912.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Hardware/SoundOuput/AY38912.cs @@ -20,7 +20,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The emulated machine (passed in via constructor) /// - private SpectrumBase _machine; + private readonly SpectrumBase _machine; private int _tStatesPerFrame; private int _sampleRate; @@ -401,7 +401,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The frequency of the AY chip /// - private static int _chipFrequency = 1773400; + private static readonly int _chipFrequency = 1773400; /// /// The rendering resolution of the chip @@ -496,7 +496,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// Panning table list /// - private static List PanTabs = new List + private static readonly List PanTabs = new List { // MONO new uint[] { 50,50, 50,50, 50,50 }, @@ -532,7 +532,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// Volume table to be used /// - private static uint[] AYVolumes = + private static readonly uint[] AYVolumes = { 0x0000,0x0000,0x0340,0x0340,0x04C0,0x04C0,0x06F2,0x06F2, 0x0A44,0x0A44,0x0F13,0x0F13,0x1510,0x1510,0x227E,0x227E, diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/CPUMonitor.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/CPUMonitor.cs index 0105b39941..2458eef3fd 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/CPUMonitor.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/CPUMonitor.cs @@ -9,8 +9,8 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// public class CPUMonitor { - private SpectrumBase _machine; - private Z80A _cpu; + private readonly SpectrumBase _machine; + private readonly Z80A _cpu; public MachineType machineType = MachineType.ZXSpectrum48; /// diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/SpectrumBase.Input.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/SpectrumBase.Input.cs index d6c370a850..8aeae7c449 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/SpectrumBase.Input.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/SpectrumBase.Input.cs @@ -9,23 +9,23 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// public abstract partial class SpectrumBase { - string Play = "Play Tape"; - string Stop = "Stop Tape"; - string RTZ = "RTZ Tape"; - string Record = "Record Tape"; - string NextTape = "Insert Next Tape"; - string PrevTape = "Insert Previous Tape"; - string NextBlock = "Next Tape Block"; - string PrevBlock = "Prev Tape Block"; - string TapeStatus = "Get Tape Status"; + readonly string Play = "Play Tape"; + readonly string Stop = "Stop Tape"; + readonly string RTZ = "RTZ Tape"; + readonly string Record = "Record Tape"; + readonly string NextTape = "Insert Next Tape"; + readonly string PrevTape = "Insert Previous Tape"; + readonly string NextBlock = "Next Tape Block"; + readonly string PrevBlock = "Prev Tape Block"; + readonly string TapeStatus = "Get Tape Status"; - string NextDisk = "Insert Next Disk"; - string PrevDisk = "Insert Previous Disk"; - string EjectDisk = "Eject Current Disk"; - string DiskStatus = "Get Disk Status"; + readonly string NextDisk = "Insert Next Disk"; + readonly string PrevDisk = "Insert Previous Disk"; + readonly string EjectDisk = "Eject Current Disk"; + readonly string DiskStatus = "Get Disk Status"; - string HardResetStr = "Power"; - string SoftResetStr = "Reset"; + readonly string HardResetStr = "Power"; + readonly string SoftResetStr = "Reset"; bool pressed_Play; bool pressed_Stop; diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/ULA.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/ULA.cs index 2461953f98..2d3c7a9a30 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/ULA.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Machine/ULA.cs @@ -253,7 +253,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The ULA device /// - private ULA _ula; + private readonly ULA _ula; /// /// Array of rendercycle entries diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Snapshot/SZX/SZX.Methods.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Snapshot/SZX/SZX.Methods.cs index f87809efb9..0be68276de 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Snapshot/SZX/SZX.Methods.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Snapshot/SZX/SZX.Methods.cs @@ -12,7 +12,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// public partial class SZX { - private SpectrumBase _machine; + private readonly SpectrumBase _machine; private Z80A _cpu => _machine.CPU; diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/CSW/CswConverter.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/CSW/CswConverter.cs index 660bf96f19..a40d551c78 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/CSW/CswConverter.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/CSW/CswConverter.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The type of serializer /// - private MediaConverterType _formatType = MediaConverterType.CSW; + private readonly MediaConverterType _formatType = MediaConverterType.CSW; public override MediaConverterType FormatType => _formatType; /// @@ -32,7 +32,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// public override bool IsWriter => false; - private DatacorderDevice _datacorder; + private readonly DatacorderDevice _datacorder; public CswConverter(DatacorderDevice _tapeDevice) { diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/PZX/PzxConverter.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/PZX/PzxConverter.cs index 279079778d..b12c768f0f 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/PZX/PzxConverter.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/PZX/PzxConverter.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The type of serializer /// - private MediaConverterType _formatType = MediaConverterType.PZX; + private readonly MediaConverterType _formatType = MediaConverterType.PZX; public override MediaConverterType FormatType => _formatType; /// @@ -42,7 +42,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// private List> _loopCounter = new List>(); - private DatacorderDevice _datacorder; + private readonly DatacorderDevice _datacorder; public PzxConverter(DatacorderDevice _tapeDevice) { diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TAP/TapConverter.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TAP/TapConverter.cs index 6c5fa94fab..a63257299e 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TAP/TapConverter.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TAP/TapConverter.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The type of serializer /// - private MediaConverterType _formatType = MediaConverterType.TAP; + private readonly MediaConverterType _formatType = MediaConverterType.TAP; public override MediaConverterType FormatType => _formatType; /// @@ -27,7 +27,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// public override bool IsWriter => false; - private DatacorderDevice _datacorder; + private readonly DatacorderDevice _datacorder; public TapConverter(DatacorderDevice _tapeDevice) { diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TZX/TzxConverter.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TZX/TzxConverter.cs index 1d9ff5d938..27f1240e51 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TZX/TzxConverter.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/TZX/TzxConverter.cs @@ -13,7 +13,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The type of serializer /// - private MediaConverterType _formatType = MediaConverterType.TZX; + private readonly MediaConverterType _formatType = MediaConverterType.TZX; public override MediaConverterType FormatType => _formatType; /// @@ -39,9 +39,9 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// Object to keep track of loops - this assumes there is only one loop at a time /// - private List> _loopCounter = new List>(); + private readonly List> _loopCounter = new List>(); - private DatacorderDevice _datacorder; + private readonly DatacorderDevice _datacorder; public TzxConverter(DatacorderDevice _tapeDevice) { diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavConverter.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavConverter.cs index d6ce0d4fb4..687312a0ca 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavConverter.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavConverter.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// /// The type of serializer /// - private MediaConverterType _formatType = MediaConverterType.WAV; + private readonly MediaConverterType _formatType = MediaConverterType.WAV; public override MediaConverterType FormatType => _formatType; /// @@ -31,7 +31,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// Position counter /// //private int _position = 0; - private DatacorderDevice _datacorder; + private readonly DatacorderDevice _datacorder; public WavConverter(DatacorderDevice _tapeDevice) { diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavStreamReader.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavStreamReader.cs index 6cd2efa8c4..2565bafdd9 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavStreamReader.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/Media/Tape/WAV/WavStreamReader.cs @@ -8,8 +8,8 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum /// public class WavStreamReader { - private Stream m_stream; - private WavHeader m_header = new WavHeader(); + private readonly Stream m_stream; + private readonly WavHeader m_header = new WavHeader(); public WavStreamReader(Stream stream) { diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.ISettable.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.ISettable.cs index 562d22ce00..9abfb46c29 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.ISettable.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.ISettable.cs @@ -234,7 +234,7 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum public string Media { get; set; } public string OtherMisc { get; set; } - private Dictionary Data = new Dictionary(); + private readonly Dictionary Data = new Dictionary(); /// /// Detailed info to be displayed within the settings UIs diff --git a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.cs b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.cs index 81fca75ae7..2822b4f0bd 100644 --- a/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.cs +++ b/src/BizHawk.Emulation.Cores/Computers/SinclairSpectrum/ZXSpectrum.cs @@ -168,12 +168,12 @@ namespace BizHawk.Emulation.Cores.Computers.SinclairSpectrum public bool DiagRom = false; - private List diagRoms = new List + private readonly List diagRoms = new List { @"\DiagROM.v28", @"\zx-diagnostics\testrom.bin" }; - private int diagIndex = 1; + private readonly int diagIndex = 1; internal CoreComm CoreComm { get; } diff --git a/src/BizHawk.Emulation.Cores/Consoles/Atari/2600/Tia/TIA.cs b/src/BizHawk.Emulation.Cores/Consoles/Atari/2600/Tia/TIA.cs index f002e73765..7282feeb78 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Atari/2600/Tia/TIA.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Atari/2600/Tia/TIA.cs @@ -58,7 +58,7 @@ namespace BizHawk.Emulation.Cores.Atari.Atari2600 public int NominalNumScanlines => _pal ? 312 : 262; - private int[] _scanlinebuffer = new int[ScreenWidth * MaxScreenHeight]; + private readonly int[] _scanlinebuffer = new int[ScreenWidth * MaxScreenHeight]; private int[] _palette; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Atari/A7800Hawk/Maria.cs b/src/BizHawk.Emulation.Cores/Consoles/Atari/A7800Hawk/Maria.cs index 30521daa96..5634d25dba 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Atari/A7800Hawk/Maria.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Atari/A7800Hawk/Maria.cs @@ -24,7 +24,7 @@ namespace BizHawk.Emulation.Cores.Atari.A7800Hawk // technically there is no limit on the number of graphics objects, but since dma is automatically killed // at the end of a scanline, we have an effective limit - GFX_Object[] GFX_Objects = new GFX_Object[128]; + readonly GFX_Object[] GFX_Objects = new GFX_Object[128]; public byte[,] line_ram = new byte[2, 320]; byte temp_check = 0; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Belogic/Uzem.cs b/src/BizHawk.Emulation.Cores/Consoles/Belogic/Uzem.cs index 9b0b77e156..0db7f3391c 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Belogic/Uzem.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Belogic/Uzem.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Consoles.Belogic public class Uzem : WaterboxCore { private LibUzem _uze; - private bool _mouseEnabled; + private readonly bool _mouseEnabled; [CoreConstructor("UZE")] public Uzem(CoreComm comm, byte[] rom) diff --git a/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Audio.cs b/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Audio.cs index 21fc4dbc4f..508cc1bf95 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Audio.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Audio.cs @@ -8,7 +8,7 @@ namespace BizHawk.Emulation.Cores.Consoles.ChannelF /// public partial class ChannelF : ISoundProvider { - private double SampleRate = 44100; + private readonly double SampleRate = 44100; private int SamplesPerFrame; private double Period; private double CyclesPerSample; @@ -16,7 +16,7 @@ namespace BizHawk.Emulation.Cores.Consoles.ChannelF private int tone = 0; - private double[] tone_freqs = { 0, 1000, 500, 120 }; + private readonly double[] tone_freqs = { 0, 1000, 500, 120 }; #pragma warning disable CS0414 private double amplitude = 0; private double decay = 0.998; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/ChannelF.IEmulator.cs b/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/ChannelF.IEmulator.cs index 5afa545854..c3a46802bb 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/ChannelF.IEmulator.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/ChannelF.IEmulator.cs @@ -12,8 +12,8 @@ namespace BizHawk.Emulation.Cores.Consoles.ChannelF public bool DeterministicEmulation { get; set; } - private static double cpuFreq = 1.7897725; - private static double refreshRate = 60; + private static readonly double cpuFreq = 1.7897725; + private static readonly double refreshRate = 60; public int ClockPerFrame; public int FrameClock = 0; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Video.cs b/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Video.cs index 20d2591aef..2e691915c4 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Video.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Fairchild/ChannelF/Video.cs @@ -43,7 +43,7 @@ namespace BizHawk.Emulation.Cores.Consoles.ChannelF private int _y; private int _arm; - private int[] frameBuffer = new int[128 * 64]; + private readonly int[] frameBuffer = new int[128 * 64]; private void BuildFrame() { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Intellivision/Controllers/IntellivisionControllers.cs b/src/BizHawk.Emulation.Cores/Consoles/Intellivision/Controllers/IntellivisionControllers.cs index d9ca9b955d..46e1b2ea96 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Intellivision/Controllers/IntellivisionControllers.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Intellivision/Controllers/IntellivisionControllers.cs @@ -96,7 +96,7 @@ namespace BizHawk.Emulation.Cores.Intellivision "S", "SSW", "SW", "WSW", "W", "WNW", "NW", "NNW", }; - private static byte[] HandControllerButtons = + private static readonly byte[] HandControllerButtons = { 0x60, // OUTPUT_ACTION_BUTTON_BOTTOM_LEFT 0xC0, // OUTPUT_ACTION_BUTTON_BOTTOM_RIGHT @@ -177,7 +177,7 @@ namespace BizHawk.Emulation.Cores.Intellivision "Key 6", "Key 7", "Key 8", "Key 9", "Enter", "Clear" }; - private static byte[] BoolControllerButtons = + private static readonly byte[] BoolControllerButtons = { 0x60, // OUTPUT_ACTION_BUTTON_BOTTOM_LEFT 0xC0, // OUTPUT_ACTION_BUTTON_BOTTOM_RIGHT @@ -217,7 +217,7 @@ namespace BizHawk.Emulation.Cores.Intellivision private const int Deadzone = 50; - private static byte[] FloatControllerButtons = + private static readonly byte[] FloatControllerButtons = { 0x02, // E 0x06, // ENE diff --git a/src/BizHawk.Emulation.Cores/Consoles/Intellivision/STIC.cs b/src/BizHawk.Emulation.Cores/Consoles/Intellivision/STIC.cs index 4b292e3856..5b5060d7f5 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Intellivision/STIC.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Intellivision/STIC.cs @@ -22,7 +22,7 @@ namespace BizHawk.Emulation.Cores.Intellivision public Func ReadMemory; public Func WriteMemory; - private static int BORDER_OFFSET=176*8; + private static readonly int BORDER_OFFSET=176*8; public int[] BGBuffer = new int[159 * 96]; public int[] FrameBuffer = new int[176 * 208]; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/GBHawk/GBHawk.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/GBHawk/GBHawk.cs index d7bf0a1d4e..022bb0c1a9 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/GBHawk/GBHawk.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/GBHawk/GBHawk.cs @@ -76,7 +76,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.GBHawk public byte undoc_6C, undoc_72, undoc_73, undoc_74, undoc_75, undoc_76, undoc_77; public byte[] _bios; - public readonly byte[] _rom; + public readonly byte[] _rom; public readonly byte[] header = new byte[0x50]; public byte[] cart_RAM; @@ -98,7 +98,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.GBHawk public Audio audio; public SerialPort serialport; - private static byte[] GBA_override = { 0xFF, 0x00, 0xCD, 0x03, 0x35, 0xAA, 0x31, 0x90, 0x94, 0x00, 0x00, 0x00, 0x00 }; + private static readonly byte[] GBA_override = { 0xFF, 0x00, 0xCD, 0x03, 0x35, 0xAA, 0x31, 0x90, 0x94, 0x00, 0x00, 0x00, 0x00 }; [CoreConstructor("GB")] [CoreConstructor("GBC")] diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IInputPollable.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IInputPollable.cs index bec5b06ed3..2be0cf877f 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IInputPollable.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IInputPollable.cs @@ -10,6 +10,6 @@ namespace BizHawk.Emulation.Cores.Nintendo.Gameboy public IInputCallbackSystem InputCallbacks => _inputCallbacks; - private InputCallbackSystem _inputCallbacks = new InputCallbackSystem(); + private readonly InputCallbackSystem _inputCallbacks = new InputCallbackSystem(); } } diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IStatable.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IStatable.cs index 0fa068daa4..088a43ea01 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IStatable.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambatteLink.IStatable.cs @@ -74,7 +74,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.Gameboy _cablediscosignal = reader.ReadBoolean(); } - private JsonSerializer ser = new JsonSerializer { Formatting = Formatting.Indented }; + private readonly JsonSerializer ser = new JsonSerializer { Formatting = Formatting.Indented }; private class DGBSerialized { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambattePrinter.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambattePrinter.cs index 4392612105..3bfc497a67 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambattePrinter.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/GambattePrinter.cs @@ -38,8 +38,8 @@ namespace BizHawk.Emulation.Cores.Nintendo.Gameboy const ushort SerialIRQAddress = 0x58; - Gameboy gb; - PrinterCallback callback; + readonly Gameboy gb; + readonly PrinterCallback callback; LibGambatte.LinkCallback linkCallback; CommandState command_state; @@ -47,12 +47,12 @@ namespace BizHawk.Emulation.Cores.Nintendo.Gameboy bool compression; ushort length_left; - byte[] command_data = new byte[GB_PRINTER_MAX_COMMAND_LENGTH]; + readonly byte[] command_data = new byte[GB_PRINTER_MAX_COMMAND_LENGTH]; ushort command_length; ushort checksum; byte status; - byte[] image = new byte[160 * 200]; + readonly byte[] image = new byte[160 * 200]; ushort image_offset; byte compression_run_lenth; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/Sameboy.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/Sameboy.cs index fa759b719d..f730364af8 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/Sameboy.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/Gameboy/Sameboy.cs @@ -31,9 +31,9 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo.Gameboy /// private const int TICKSPERSECOND_SGB = 2147727; - private LibSameboy _core; - private bool _cgb; - private bool _sgb; + private readonly LibSameboy _core; + private readonly bool _cgb; + private readonly bool _sgb; [CoreConstructor("SGB")] public Sameboy(byte[] rom, CoreComm comm, Settings settings, SyncSettings syncSettings, bool deterministic) @@ -304,7 +304,7 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo.Gameboy public bool IsCGBMode() => _cgb; - private GPUMemoryAreas _gpuMemory; + private readonly GPUMemoryAreas _gpuMemory; public GPUMemoryAreas GetGPU() => _gpuMemory; private ScanlineCallback _scanlineCallback; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IMemoryDomains.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IMemoryDomains.cs index 4cdd0be192..abb4e09f7d 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IMemoryDomains.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IMemoryDomains.cs @@ -9,7 +9,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64 { public partial class N64 { - private List _memoryDomains = new List(); + private readonly List _memoryDomains = new List(); private IMemoryDomains MemoryDomains; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IStatable.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IStatable.cs index c22ca0dfef..c47277536c 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IStatable.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.IStatable.cs @@ -51,6 +51,6 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64 Frame = reader.ReadInt32(); } - private byte[] SaveStatePrivateBuff = new byte[16788288 + 1024]; + private readonly byte[] SaveStatePrivateBuff = new byte[16788288 + 1024]; } } diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.cs index ebb2d5f82d..6b81c7d47a 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64.cs @@ -154,11 +154,11 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64 private bool _pendingThreadTerminate; - private DisplayType _display_type = DisplayType.NTSC; + private readonly DisplayType _display_type = DisplayType.NTSC; private Action _pendingThreadAction; - private bool _disableExpansionSlot = true; + private readonly bool _disableExpansionSlot = true; public IEmulatorServiceProvider ServiceProvider { get; } diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64Audio.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64Audio.cs index 6934951db7..639c6d6eba 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64Audio.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64Audio.cs @@ -11,7 +11,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64 /// private mupen64plusAudioApi api; - private mupen64plusApi coreAPI; + private readonly mupen64plusApi coreAPI; /// /// Buffer for audio data diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64VideoProvider.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64VideoProvider.cs index adcf09fc29..bd9dc75aa4 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64VideoProvider.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/N64VideoProvider.cs @@ -8,7 +8,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64 { private int[] frameBuffer; private mupen64plusVideoApi api; - private mupen64plusApi coreAPI; + private readonly mupen64plusApi coreAPI; public bool IsVIFrame; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusAudioApi.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusAudioApi.cs index 6901b7d0b3..773b20fef2 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusAudioApi.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusAudioApi.cs @@ -16,7 +16,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// The size of the mupen64plus audio buffer [UnmanagedFunctionPointer(CallingConvention.Cdecl)] private delegate int GetBufferSize(); - GetBufferSize dllGetBufferSize; + readonly GetBufferSize dllGetBufferSize; /// /// Gets the audio buffer from mupen64plus, and then clears it @@ -24,7 +24,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// The buffer to fill with samples [UnmanagedFunctionPointer(CallingConvention.Cdecl)] private delegate void ReadAudioBuffer(short[] dest); - ReadAudioBuffer dllReadAudioBuffer; + readonly ReadAudioBuffer dllReadAudioBuffer; /// /// Gets the current audio rate from mupen64plus @@ -32,7 +32,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// The current audio rate [UnmanagedFunctionPointer(CallingConvention.Cdecl)] private delegate int GetAudioRate(); - GetAudioRate dllGetAudioRate; + readonly GetAudioRate dllGetAudioRate; /// /// Loads native functions and attaches itself to the core diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusCoreApi.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusCoreApi.cs index e735100b0f..cc420860bb 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusCoreApi.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusCoreApi.cs @@ -19,11 +19,11 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi bool disposed = false; - Thread m64pEmulator; + readonly Thread m64pEmulator; - AutoResetEvent m64pEvent = new AutoResetEvent(false); + readonly AutoResetEvent m64pEvent = new AutoResetEvent(false); AutoResetEvent m64pContinueEvent = new AutoResetEvent(false); - ManualResetEvent m64pStartupComplete = new ManualResetEvent(false); + readonly ManualResetEvent m64pStartupComplete = new ManualResetEvent(false); bool event_frameend = false; bool event_breakpoint = false; @@ -978,7 +978,8 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi public DynamicLibraryImportResolver dllThinWrapper; public PluginShutdown dllShutdown; } - Dictionary plugins = new Dictionary(); + + readonly Dictionary plugins = new Dictionary(); public IntPtr AttachPlugin(m64p_plugin_type type, string PluginName) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusInputApi.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusInputApi.cs index cbf5566ced..4a2e2c6427 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusInputApi.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusInputApi.cs @@ -13,7 +13,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// The delegate to use [UnmanagedFunctionPointer(CallingConvention.Cdecl)] private delegate void SetInputCallback(InputCallback inputCallback); - SetInputCallback InpSetInputCallback; + readonly SetInputCallback InpSetInputCallback; /// /// Callback to use when mupen64plus wants input @@ -41,7 +41,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// Type id according to (well documented... hurr hurr) mupen api [UnmanagedFunctionPointer(CallingConvention.Cdecl)] public delegate void SetControllerPakType(int controller, int type); - SetControllerPakType InpSetControllerPakType; + readonly SetControllerPakType InpSetControllerPakType; /// /// Connects and disconnects controllers @@ -50,7 +50,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// 1 if controller should be connected, 0 if controller should be disconnected [UnmanagedFunctionPointer(CallingConvention.Cdecl)] delegate void SetControllerConnected(int controller, int connected); - SetControllerConnected InpSetControllerConnected; + readonly SetControllerConnected InpSetControllerConnected; /// /// Event fired when mupen changes rumble pak status diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusVideoApi.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusVideoApi.cs index fd0ad53403..e0f4ed186a 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusVideoApi.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/N64/NativeApi/mupen64plusVideoApi.cs @@ -18,7 +18,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// Which buffer to read: 0 = front, 1 = back [UnmanagedFunctionPointer(CallingConvention.Cdecl)] private delegate void ReadScreen2(int[] framebuffer, ref int width, ref int height, int buffer); - ReadScreen2 GFXReadScreen2; + readonly ReadScreen2 GFXReadScreen2; /// /// Gets the width and height of the mupen64plus framebuffer @@ -29,9 +29,8 @@ namespace BizHawk.Emulation.Cores.Nintendo.N64.NativeApi /// Which buffer to read: 0 = front, 1 = back [UnmanagedFunctionPointer(CallingConvention.Cdecl)] private delegate void ReadScreen2Res(IntPtr dummy, ref int width, ref int height, int buffer); - ReadScreen2Res GFXReadScreen2Res; + readonly ReadScreen2Res GFXReadScreen2Res; - [UnmanagedFunctionPointer(CallingConvention.Cdecl)] private delegate int GetScreenTextureID(); GetScreenTextureID GFXGetScreenTextureID; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/APU.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/APU.cs index cecf8174d0..e6b912a973 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/APU.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/APU.cs @@ -26,7 +26,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public bool recalculate = false; - NES nes; + readonly NES nes; public APU(NES nes, APU old, bool pal) { this.nes = nes; @@ -43,25 +43,25 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES } } - static int[] DMC_RATE_NTSC = { 428, 380, 340, 320, 286, 254, 226, 214, 190, 160, 142, 128, 106, 84, 72, 54 }; - static int[] DMC_RATE_PAL = { 398, 354, 316, 298, 276, 236, 210, 198, 176, 148, 132, 118, 98, 78, 66, 50 }; - static int[] LENGTH_TABLE = { 10, 254, 20, 2, 40, 4, 80, 6, 160, 8, 60, 10, 14, 12, 26, 14, 12, 16, 24, 18, 48, 20, 96, 22, 192, 24, 72, 26, 16, 28, 32, 30 }; - static byte[,] PULSE_DUTY = { + static readonly int[] DMC_RATE_NTSC = { 428, 380, 340, 320, 286, 254, 226, 214, 190, 160, 142, 128, 106, 84, 72, 54 }; + static readonly int[] DMC_RATE_PAL = { 398, 354, 316, 298, 276, 236, 210, 198, 176, 148, 132, 118, 98, 78, 66, 50 }; + static readonly int[] LENGTH_TABLE = { 10, 254, 20, 2, 40, 4, 80, 6, 160, 8, 60, 10, 14, 12, 26, 14, 12, 16, 24, 18, 48, 20, 96, 22, 192, 24, 72, 26, 16, 28, 32, 30 }; + static readonly byte[,] PULSE_DUTY = { {0,1,0,0,0,0,0,0}, // (12.5%) {0,1,1,0,0,0,0,0}, // (25%) {0,1,1,1,1,0,0,0}, // (50%) {1,0,0,1,1,1,1,1}, // (25% negated (75%)) }; - static byte[] TRIANGLE_TABLE = + static readonly byte[] TRIANGLE_TABLE = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 }; - static int[] NOISE_TABLE_NTSC = + static readonly int[] NOISE_TABLE_NTSC = { 4, 8, 16, 32, 64, 96, 128, 160, 202, 254, 380, 508, 762, 1016, 2034, 4068 }; - static int[] NOISE_TABLE_PAL = + static readonly int[] NOISE_TABLE_PAL = { 4, 7, 14, 30, 60, 88, 118, 148, 188, 236, 354, 472, 708, 944, 1890, 3778 }; @@ -70,7 +70,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES { public PulseUnit(APU apu, int unit) { this.unit = unit; this.apu = apu; } public int unit; - APU apu; + readonly APU apu; // reg0 int duty_cnt, env_loop, env_constant, env_cnt_value; @@ -309,7 +309,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public sealed class NoiseUnit { - APU apu; + readonly APU apu; // reg0 (sweep) int env_cnt_value, env_loop, env_constant; @@ -331,7 +331,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES int env_output, env_start_flag, env_divider, env_counter; bool noise_bit = true; - int[] NOISE_TABLE; + readonly int[] NOISE_TABLE; public NoiseUnit(APU apu, bool pal) { @@ -508,7 +508,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES int seq = 0; public int sample; - APU apu; + readonly APU apu; public TriangleUnit(APU apu) { this.apu = apu; } public void SyncState(Serializer ser) @@ -648,8 +648,8 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES sealed class DMCUnit { - APU apu; - int[] DMC_RATE; + readonly APU apu; + readonly int[] DMC_RATE; public DMCUnit(APU apu, bool pal) { this.apu = apu; @@ -940,7 +940,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public PulseUnit[] pulse = new PulseUnit[2]; public TriangleUnit triangle; public NoiseUnit noise; - DMCUnit dmc; + readonly DMCUnit dmc; bool irq_pending; bool dmc_irq; @@ -959,14 +959,14 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES dmc.Fetch(); } - int[][] sequencer_lut = new int[2][]; + readonly int[][] sequencer_lut = new int[2][]; - static int[][] sequencer_lut_ntsc = { + static readonly int[][] sequencer_lut_ntsc = { new[]{7457,14913,22371,29830}, new[]{7457,14913,22371,29830,37282} }; - static int[][] sequencer_lut_pal = { + static readonly int[][] sequencer_lut_pal = { new[]{8313,16627,24939,33254}, new[]{8313,16627,24939,33254,41566} }; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/BANDAI-FCG-1.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/BANDAI-FCG-1.cs index 05202fbcf0..9ee6e1caf2 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/BANDAI-FCG-1.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/BANDAI-FCG-1.cs @@ -42,7 +42,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES byte jump2_outer_bank; // needed to select between banks in 512K jump2 board //regenerable state - int[] prg_banks_16k = new int[2]; + readonly int[] prg_banks_16k = new int[2]; //state int prg_reg_16k; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/GameGenie.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/GameGenie.cs index 5651b83a47..174256aec1 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/GameGenie.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/GameGenie.cs @@ -6,7 +6,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES internal sealed class GameGenie : NesBoardBase { - static byte[] PatternTables = new byte[256]; + static readonly byte[] PatternTables = new byte[256]; static GameGenie() { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper114.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper114.cs index ddef1ddd0b..5ba203ef6d 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper114.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper114.cs @@ -9,7 +9,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES private int prg_mask_16; - private byte[] sec = { 0, 3, 1, 5, 6, 7, 2, 4 }; + private readonly byte[] sec = { 0, 3, 1, 5, 6, 7, 2, 4 }; public override bool Configure(EDetectionOrigin origin) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper123.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper123.cs index f009804f69..0d2b8f49ec 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper123.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper123.cs @@ -7,7 +7,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES { private byte[] EXPREGS = new byte[8]; - private byte[] sec = { 0, 3, 1, 5, 6, 7, 2, 4 }; + private readonly byte[] sec = { 0, 3, 1, 5, 6, 7, 2, 4 }; public override bool Configure(EDetectionOrigin origin) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper182.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper182.cs index 4b703dc56d..5b3ee7fca3 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper182.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper182.cs @@ -41,11 +41,11 @@ } } - static byte[] scramble_table = { 0, 3, 1, 5, 6, 7, 2, 4 }; - static int scramble_A000(byte val) + static readonly byte[] scramble_table = { 0, 3, 1, 5, 6, 7, 2, 4 }; + + private static int scramble_A000(byte val) { return (val & ~0x7) | scramble_table[val & 0x7]; } - } } \ No newline at end of file diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper215.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper215.cs index 22ff312e97..280afb72e7 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper215.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper215.cs @@ -12,7 +12,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES private int prg_mask_8k, chr_mask_1k; - private byte[] regs_sec = { 0, 2, 5, 3, 6, 1, 7, 4 }; + private readonly byte[] regs_sec = { 0, 2, 5, 3, 6, 1, 7, 4 }; /* * I'm not sure where these matrices originated from, but they don't seem to be needed diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper217.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper217.cs index 9410f9b47e..2b8f5385d1 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper217.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Mapper217.cs @@ -8,7 +8,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public byte[] prg_regs_8k = new byte[4]; private int prg_mask_8k, chr_mask_1k; - private byte[] regs_sec = { 0, 6, 3, 7, 5, 2, 4, 1 }; + private readonly byte[] regs_sec = { 0, 6, 3, 7, 5, 2, 4, 1 }; public override bool Configure(EDetectionOrigin origin) diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Pocahontas.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Pocahontas.cs index f6a966d6f1..2024d02cae 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Pocahontas.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/MMC3_family/Pocahontas.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES private int prg_mask_8k, chr_mask_1k; - private byte[] regs_sec = { 0, 2, 6, 1, 7, 3, 4, 5 }; + private readonly byte[] regs_sec = { 0, 2, 6, 1, 7, 3, 4, 5 }; public override bool Configure(EDetectionOrigin origin) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper043.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper043.cs index 1a2dfc85c5..3058984f48 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper043.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper043.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES bool swap; - private static int[] lut = { 4, 3, 5, 3, 6, 3, 7, 3 }; + private static readonly int[] lut = { 4, 3, 5, 3, 6, 3, 7, 3 }; public override bool Configure(EDetectionOrigin origin) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper116.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper116.cs index 7e0fd12741..062a77ddcd 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper116.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper116.cs @@ -33,7 +33,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES master.SyncIRQ(flag); } - Mapper116 master; + readonly Mapper116 master; } diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper156.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper156.cs index bc5eccc82b..6e3bbe9a29 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper156.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper156.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES int prg_mask; int chr_mask; int prg; - int[] chr = new int[8]; + readonly int[] chr = new int[8]; public override bool Configure(EDetectionOrigin origin) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper244.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper244.cs index 98659cb00a..146f87e441 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper244.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Mapper244.cs @@ -18,7 +18,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES return true; } - private List> prg_perm = new List> + private readonly List> prg_perm = new List> { new List { 0, 1, 2, 3, }, new List { 3, 2, 1, 0, }, @@ -26,7 +26,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES new List { 3, 1, 2, 0, }, }; - private List> chr_perm = new List> + private readonly List> chr_perm = new List> { new List { 0, 1, 2, 3, 4, 5, 6, 7, }, new List { 0, 2, 1, 3, 4, 6, 5, 7, }, diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/NSFBoard.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/NSFBoard.cs index 664352c94f..1fdce6af09 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/NSFBoard.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/NSFBoard.cs @@ -33,12 +33,12 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES /// /// the bankswitch values to be used before the INIT routine is called /// - byte[] InitBankSwitches = new byte[8]; + readonly byte[] InitBankSwitches = new byte[8]; /// /// An image of the entire PRG space where the unmapped files are located /// - byte[] FakePRG = new byte[32768]; + readonly byte[] FakePRG = new byte[32768]; //------------------------------ //state @@ -240,7 +240,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //3FF3 - PatchVectors=false //3FF4 - PatchVectors=true - byte[] NSFROM = new byte[0x23] + readonly byte[] NSFROM = new byte[0x23] { //@NMIVector //Suspend vector patching diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot129_163.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot129_163.cs index 12a91dfa28..bbd265d1a2 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot129_163.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot129_163.cs @@ -23,7 +23,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //state int[] prg_banks_8k = new int[4]; int[] chr_banks_1k = new int[12]; - bool[] vram_enable = new bool[3]; + readonly bool[] vram_enable = new bool[3]; int irq_counter; bool irq_enabled; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namco163Audio.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namco163Audio.cs index a1098050fe..a0b811d6b9 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namco163Audio.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namco163Audio.cs @@ -102,7 +102,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES ser.Sync(nameof(ch), ref ch); } - Action enqueuer; + readonly Action enqueuer; public Namco163Audio(Action enqueuer) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namcot1xx.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namcot1xx.cs index d2122fe458..ac2a3c47f3 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namcot1xx.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Namcot1xx/Namcot1xx.cs @@ -96,7 +96,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES // security reading index for tko boxing int tko_security = 0; - static byte[] TKO = { 0xFF, 0xBF, 0xB7, 0x97, 0x97, 0x17, 0x57, 0x4F, 0x6F, 0x6B, 0xEB, 0xA9, 0xB1, 0x90, 0x94, 0x14, + static readonly byte[] TKO = { 0xFF, 0xBF, 0xB7, 0x97, 0x97, 0x17, 0x57, 0x4F, 0x6F, 0x6B, 0xEB, 0xA9, 0xB1, 0x90, 0x94, 0x14, 0x56, 0x4E, 0x6F, 0x6B, 0xEB, 0xA9, 0xB1, 0x90, 0xD4, 0x5C, 0x3E, 0x26, 0x87, 0x83, 0x13, 0x51}; public override void SyncState(Serializer ser) diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/PxROM_FxROM.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/PxROM_FxROM.cs index fcdf654ea8..47975f7a01 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/PxROM_FxROM.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/PxROM_FxROM.cs @@ -13,7 +13,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //state byte prg_reg; - int[] prg_banks_8k = new int[4]; + readonly int[] prg_banks_8k = new int[4]; int[] chr_banks_4k = new int[4]; int[] chr_latches = new int[2]; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/SEEPROM.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/SEEPROM.cs index 9f72a11ecb..13981cbeef 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/SEEPROM.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/SEEPROM.cs @@ -16,7 +16,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES /// /// true if 256byte /// - bool Big; + readonly bool Big; byte[] rom; /// aux circuitry? D7 of data byte diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/TENGEN-800032.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/TENGEN-800032.cs index 48780d420a..9d1ac5c298 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/TENGEN-800032.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/TENGEN-800032.cs @@ -6,18 +6,20 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //AKA mapper 64 internal sealed class TENGEN_800032 : NesBoardBase { - //configuration + // configuration int prg_bank_mask_8k; int chr_bank_mask_1k; - //regenerable state - int[] prg_banks_8k = new int[4]; - int[] chr_banks_1k = new int[8]; - //state + // regenerable state + readonly int[] prg_banks_8k = new int[4]; + readonly int[] chr_banks_1k = new int[8]; + + // state int[] regs = new int[16]; int address; bool chr_1k, chr_mode, prg_mode; - //irq + + // irq int irq_countdown; int a12_old; int irq_reload, irq_counter; @@ -191,7 +193,6 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES return Rom[addr]; } - public override byte ReadPpu(int addr) { if (addr < 0x2000) @@ -328,6 +329,5 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES a12_old = a12; } - } } \ No newline at end of file diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Taito_X1_017.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Taito_X1_017.cs index 7fb9159d82..9e575eb9cb 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Taito_X1_017.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/Taito_X1_017.cs @@ -10,7 +10,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES private byte[] prg_regs_8k = new byte[4]; private byte[] chr_regs_1k = new byte[8]; private bool ChrMode; - private bool[] wramenable = new bool[3]; + private readonly bool[] wramenable = new bool[3]; public override void SyncState(Serializer ser) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-D1038.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-D1038.cs index b29690a004..d31239852f 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-D1038.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-D1038.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES private int _reg; - private int DipswitchMask = 3; + private readonly int DipswitchMask = 3; private bool Prg16kMode => _reg.Bit(7); diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-GS-2013.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-GS-2013.cs index 1e01c40e05..a2a533df52 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-GS-2013.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_BMC-GS-2013.cs @@ -11,11 +11,11 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES private int _reg = 0xFF; private bool _isRom2 = true; - private int _prgMaskRom1 = 7; - private int _prgMaskRom2 = 1; + private readonly int _prgMaskRom1 = 7; + private readonly int _prgMaskRom2 = 1; - private int _wramPage = 0x3E000; - private int _rom2Offset = 0x40000; + private readonly int _wramPage = 0x3E000; + private readonly int _rom2Offset = 0x40000; public override bool Configure(EDetectionOrigin origin) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_UNL_DripGame.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_UNL_DripGame.cs index bde4fa18de..81e258991d 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_UNL_DripGame.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/UNIF/UNIF_UNL_DripGame.cs @@ -300,7 +300,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES int latched; // communicate with APU - Action enqueuer; + readonly Action enqueuer; // true if V has been written and we need to check to change something bool volumeChangePending; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC1.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC1.cs index 7c35470b16..30c17444f3 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC1.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC1.cs @@ -13,7 +13,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //state int[] prg_banks_8k = new int[4]; int[] chr_banks_4k = new int[2]; - int[] chr_regs_4k = new int[2]; + readonly int[] chr_regs_4k = new int[2]; //the VS actually does have 2 KB of nametable address space //let's make the extra space here, instead of in the main NES to avoid confusion diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC2_4.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC2_4.cs index 4e9a1d60e2..0f0dd4f27e 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC2_4.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC2_4.cs @@ -66,7 +66,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES private bool extrabig_chr = false; //state - private int[] prg_bank_reg_8k = new int[2]; + private readonly int[] prg_bank_reg_8k = new int[2]; public int[] chr_bank_reg_1k = new int[16]; private bool _prgMode; public byte[] prg_banks_8k = new byte[4]; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC6.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC6.cs index fbcc01da49..5b04f598ab 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC6.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Boards/VRC6.cs @@ -13,11 +13,11 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES // what did i do in a previous life to deserve this? // given the bottom four bits of $b003, and a 1K address region in PPU $0000:$3fff, - static byte[] Banks = new byte[16 * 16]; // which of the 8 chr regs is used to determine the bank here? - static byte[] Masks = new byte[16 * 16]; // what is the resulting 8 bit chr reg value ANDed with? - static byte[] A10s = new byte[16 * 16]; // and then what is it ORed with? + static readonly byte[] Banks = new byte[16 * 16]; // which of the 8 chr regs is used to determine the bank here? + static readonly byte[] Masks = new byte[16 * 16]; // what is the resulting 8 bit chr reg value ANDed with? + static readonly byte[] A10s = new byte[16 * 16]; // and then what is it ORed with? - static byte[] PTables = + static readonly byte[] PTables = { 0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07, 0x80,0xc0,0x81,0xc1,0x82,0xc2,0x83,0xc3, @@ -113,7 +113,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //state int prg_bank_16k, prg_bank_8k; - byte[] prg_banks_8k = new byte[4]; + readonly byte[] prg_banks_8k = new byte[4]; byte[] chr_banks_1k = new byte[8]; bool irq_mode; bool irq_enabled, irq_pending, irq_autoen; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/BootGodDB.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/BootGodDB.cs index 44eb7921e1..92d2f0e52d 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/BootGodDB.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/BootGodDB.cs @@ -10,12 +10,12 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES { public class BootGodDb { - /// - /// blocks until the DB is done loading - /// + /// + /// blocks until the DB is done loading + /// static EventWaitHandle acquire; - bool validate = true; + readonly bool validate = true; private readonly Bag _sha1Table = new Bag(); diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSAudio.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSAudio.cs index 84439ea181..ac71c14313 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSAudio.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSAudio.cs @@ -146,7 +146,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES int latchedoutput; - Action SendDiff; + readonly Action SendDiff; public FDSAudio(Action SendDiff) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSInspector.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSInspector.cs index 7000ba54a3..3317b4fd74 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSInspector.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/FDS/FDSInspector.cs @@ -13,8 +13,8 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public class FDSFile { - static byte[] Check = FTXT.E.GetBytes("FDS\x1a"); - static byte[] CheckAlt = FTXT.E.GetBytes("\x01*NIN"); + static readonly byte[] Check = FTXT.E.GetBytes("FDS\x1a"); + static readonly byte[] CheckAlt = FTXT.E.GetBytes("\x01*NIN"); public List Disks = new List(); @@ -61,7 +61,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public class FDSDisk { - static byte[] Check = FTXT.E.GetBytes("*NINTENDO-HVC*"); + static readonly byte[] Check = FTXT.E.GetBytes("*NINTENDO-HVC*"); public List Chunks = new List(); diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.BoardSystem.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.BoardSystem.cs index 5a3aff80dc..3ae85e815c 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.BoardSystem.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.BoardSystem.cs @@ -7,7 +7,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES { partial class NES { - static List INESBoardImplementors = new List(); + static readonly List INESBoardImplementors = new List(); private static INesBoard CreateBoardInstance(Type boardType) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.Core.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.Core.cs index 147965ed4f..de58c02064 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.Core.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.Core.cs @@ -58,7 +58,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public int num_cheats; // new input system - NESControlSettings ControllerSettings; // this is stored internally so that a new change of settings won't replace + readonly NESControlSettings ControllerSettings; // this is stored internally so that a new change of settings won't replace IControllerDeck ControllerDeck; byte latched4016; @@ -429,8 +429,8 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //NTSC: //sequence of ppu clocks per cpu clock: 3 public byte[] cpu_sequence; - static byte[] cpu_sequence_NTSC = { 3, 3, 3, 3, 3 }; - static byte[] cpu_sequence_PAL = { 3, 3, 3, 4, 3 }; + static readonly byte[] cpu_sequence_NTSC = { 3, 3, 3, 3, 3 }; + static readonly byte[] cpu_sequence_PAL = { 3, 3, 3, 4, 3 }; public int cpu_deadcounter; public int oam_dma_index; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.cs index 36db961482..1f854cbd72 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/NES.cs @@ -138,14 +138,13 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES //public int pal_bottom = 239; public int left = 0; public int right = 255; - - NES emu; + readonly NES emu; public MyVideoProvider(NES emu) { this.emu = emu; } - int[] pixels = new int[256 * 240]; + readonly int[] pixels = new int[256 * 240]; public int[] GetVideoBuffer() { return pixels; @@ -300,7 +299,8 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES { loadReport = _loadReport; } - TextWriter loadReport; + + readonly TextWriter loadReport; public override void WriteLine(string format, params object[] arg) { Console.WriteLine(format, arg); diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/PPU.run.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/PPU.run.cs index 62236c9a0d..34047457d0 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/PPU.run.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/PPU.run.cs @@ -55,7 +55,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES public byte patterns_1; } - TempOAM[] t_oam = new TempOAM[64]; + readonly TempOAM[] t_oam = new TempOAM[64]; int ppu_addr_temp; @@ -131,7 +131,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES bool nmi_destiny; bool evenOddDestiny; - static int start_up_offset = 2; + static readonly int start_up_offset = 2; int NMI_offset; int yp_shift; int sprite_eval_cycle; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Palettes.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Palettes.cs index 9afdeeb440..9ff8f6a14f 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Palettes.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/NES/Palettes.cs @@ -2,9 +2,9 @@ namespace BizHawk.Emulation.Cores.Nintendo.NES { public static class Palettes { - static float[] rtmul = { 1.239f, 0.794f, 1.019f, 0.905f, 1.023f, 0.741f, 0.75f }; - static float[] gtmul = { 0.915f, 1.086f, 0.98f, 1.026f, 0.908f, 0.987f, 0.75f }; - static float[] btmul = { 0.743f, 0.882f, 0.653f, 1.277f, 0.979f, 0.101f, 0.75f }; + static readonly float[] rtmul = { 1.239f, 0.794f, 1.019f, 0.905f, 1.023f, 0.741f, 0.75f }; + static readonly float[] gtmul = { 0.915f, 1.086f, 0.98f, 1.026f, 0.908f, 0.987f, 0.75f }; + static readonly float[] btmul = { 0.743f, 0.882f, 0.653f, 1.277f, 0.979f, 0.101f, 0.75f }; public static void ApplyDeemphasis(ref int r, ref int g, ref int b, int deemph_bits) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/QuickNES/QuickNES.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/QuickNES/QuickNES.cs index a82fc50b9d..a9ea7ef4e5 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/QuickNES/QuickNES.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/QuickNES/QuickNES.cs @@ -121,7 +121,7 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo.QuickNES public void Dispose() {} } - IFPCtrl FP; + readonly IFPCtrl FP; public ControllerDefinition ControllerDefinition { get; private set; } @@ -154,17 +154,17 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo.QuickNES return PadNames.Zip(PadMasks, (s, i) => new PadEnt(prefix + s, i)).ToArray(); } - private static string[] PadNames = + private static readonly string[] PadNames = { "Up", "Down", "Left", "Right", "Start", "Select", "B", "A" }; - private static int[] PadMasks = + private static readonly int[] PadMasks = { 16, 32, 64, 128, 8, 4, 2, 1 }; - private static PadEnt[] PadP1 = GetPadList(1); - private static PadEnt[] PadP2 = GetPadList(2); + private static readonly PadEnt[] PadP1 = GetPadList(1); + private static readonly PadEnt[] PadP2 = GetPadList(2); private int GetPad(IController controller, IEnumerable buttons) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesApi.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesApi.cs index edbf3d03d1..e954056803 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesApi.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesApi.cs @@ -290,13 +290,13 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES { [FieldOffset(0)] //the cmd being executed - public eMessage cmd; + public readonly eMessage cmd; [FieldOffset(4)] //the status of the core - public eStatus status; + public readonly eStatus status; [FieldOffset(8)] //the SIG or BRK that the core is halted in - public eMessage reason; + public readonly eMessage reason; //flexible in/out parameters //these are all "overloaded" a little so it isn't clear what's used for what in for any particular message.. diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesCore.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesCore.cs index a5e13fa7a2..3e65c3d9da 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesCore.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/LibsnesCore.cs @@ -226,7 +226,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES private readonly LibsnesApi.snes_audio_sample_t _soundcb; private IController _controller; - private LoadParams _currLoadParams; + private readonly LoadParams _currLoadParams; private SpeexResampler _resampler; private int _timeFrameCounter; private bool _disposed; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SNESGraphicsDecoder.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SNESGraphicsDecoder.cs index 6ae4ceeade..5cb9fcee48 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SNESGraphicsDecoder.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SNESGraphicsDecoder.cs @@ -191,7 +191,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES public class BGInfos { - BGInfo[] bgs = new BGInfo[4] { new BGInfo(1), new BGInfo(2), new BGInfo(3), new BGInfo(4) }; + readonly BGInfo[] bgs = new BGInfo[4] { new BGInfo(1), new BGInfo(2), new BGInfo(3), new BGInfo(4) }; public BGInfo BG1 => bgs[0]; public BGInfo BG2 => bgs[1]; public BGInfo BG3 => bgs[2]; @@ -497,7 +497,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES } } - static int[,] ModeBpps = { + static readonly int[,] ModeBpps = { {2,2,2,2}, {4,4,2,0}, {4,4,0,0}, @@ -516,7 +516,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES } //the same basic color table that libsnes uses to convert from snes 555 to rgba32 - static int[] directColorTable = new int[256]; //8bpp gfx -> rgb555 + static readonly int[] directColorTable = new int[256]; //8bpp gfx -> rgb555 static SNESGraphicsDecoder() { //make directColorTable @@ -533,11 +533,11 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES } } - int[] colortable; + readonly int[] colortable; public byte* vram, oam; public ushort* cgram, vram16; - - LibsnesApi api; + + readonly LibsnesApi api; public SNESGraphicsDecoder(LibsnesApi api, SnesColors.ColorType pal) { @@ -764,7 +764,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES } } - int[][] _tileCache = new int[18][]; + readonly int[][] _tileCache = new int[18][]; bool usingUserBackColor = false; int userBackColor; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SnesColors.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SnesColors.cs index 6199e445ac..b39346b387 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SnesColors.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES/SnesColors.cs @@ -28,7 +28,7 @@ } // LUT from snes9x - static byte[,] mul_brightness = + static readonly byte[,] mul_brightness = { { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES9X/Snes9x.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES9X/Snes9x.cs index a1884871d7..8f42c1fc1a 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES9X/Snes9x.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/SNES9X/Snes9x.cs @@ -17,7 +17,7 @@ namespace BizHawk.Emulation.Cores.Nintendo.SNES9X public class Snes9x : WaterboxCore, ISettable, IRegionable { - private LibSnes9x _core; + private readonly LibSnes9x _core; [CoreConstructor("SNES")] public Snes9x(CoreComm comm, byte[] rom, Settings settings, SyncSettings syncSettings) diff --git a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/VB/VirtualBoyee.cs b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/VB/VirtualBoyee.cs index dbc62766e6..25f5c6ff33 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Nintendo/VB/VirtualBoyee.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Nintendo/VB/VirtualBoyee.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo.VB "https://mednafen.github.io/releases/", false, "VirtualBoy")] public class VirtualBoyee : WaterboxCore, ISettable { - private LibVirtualBoyee _boyee; + private readonly LibVirtualBoyee _boyee; [CoreConstructor("VB")] public VirtualBoyee(CoreComm comm, byte[] rom, Settings settings, SyncSettings syncSettings) diff --git a/src/BizHawk.Emulation.Cores/Consoles/PC Engine/PCEngine.cs b/src/BizHawk.Emulation.Cores/Consoles/PC Engine/PCEngine.cs index 7b78a05ac4..ad3f1393fd 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/PC Engine/PCEngine.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/PC Engine/PCEngine.cs @@ -123,7 +123,7 @@ namespace BizHawk.Emulation.Cores.PCEngine // ROM private byte[] RomData; private int RomLength; - private Disc disc; + private readonly Disc disc; // Machine public NecSystemType Type; diff --git a/src/BizHawk.Emulation.Cores/Consoles/PC Engine/ScsiCDBus.cs b/src/BizHawk.Emulation.Cores/Consoles/PC Engine/ScsiCDBus.cs index 7363033a9e..62a03f32f0 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/PC Engine/ScsiCDBus.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/PC Engine/ScsiCDBus.cs @@ -137,7 +137,7 @@ namespace BizHawk.Emulation.Cores.PCEngine bool StatusCompleted; byte MessageValue; - QuickList CommandBuffer = new QuickList(10); // 10 = biggest command + readonly QuickList CommandBuffer = new QuickList(10); // 10 = biggest command public QuickQueue DataIn = new QuickQueue(2048); // one data sector // ******** Data Transfer / READ command support ******** @@ -151,9 +151,9 @@ namespace BizHawk.Emulation.Cores.PCEngine // ******** Resources ******** - private PCEngine pce; + private readonly PCEngine pce; public Disc disc; - private DiscSectorReader DiscSectorReader; + private readonly DiscSectorReader DiscSectorReader; private SubchannelQ subchannelQ; private int audioStartLBA; private int audioEndLBA; diff --git a/src/BizHawk.Emulation.Cores/Consoles/PC Engine/VPC.cs b/src/BizHawk.Emulation.Cores/Consoles/PC Engine/VPC.cs index 430b66c5b6..4f434bbc47 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/PC Engine/VPC.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/PC Engine/VPC.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.PCEngine public sealed class VPC : IVideoProvider { - PCEngine PCE; + readonly PCEngine PCE; public VDC VDC1; public VDC VDC2; public VCE VCE; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sega/PicoDrive/PicoDrive.cs b/src/BizHawk.Emulation.Cores/Consoles/Sega/PicoDrive/PicoDrive.cs index 5491733af9..d322c3e2e4 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sega/PicoDrive/PicoDrive.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sega/PicoDrive/PicoDrive.cs @@ -13,11 +13,11 @@ namespace BizHawk.Emulation.Cores.Consoles.Sega.PicoDrive "0e352905c7aa80b166933970abbcecfce96ad64e", "https://github.com/notaz/picodrive", false)] public class PicoDrive : WaterboxCore, IDriveLight, IRegionable, ISettable { - private LibPicoDrive _core; - private LibPicoDrive.CDReadCallback _cdcallback; - private Disc _cd; - private DiscSectorReader _cdReader; - private bool _isPal; + private readonly LibPicoDrive _core; + private readonly LibPicoDrive.CDReadCallback _cdcallback; + private readonly Disc _cd; + private readonly DiscSectorReader _cdReader; + private readonly bool _isPal; [CoreConstructor("GEN", Priority = CorePriority.Low)] [CoreConstructor("32X")] diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/SMS.cs b/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/SMS.cs index 354cc31738..957bf1bddd 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/SMS.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/SMS.cs @@ -228,8 +228,8 @@ namespace BizHawk.Emulation.Cores.Sega.MasterSystem public byte[] RomData; private byte RomBank0, RomBank1, RomBank2, RomBank3; private byte Bios_bank; - private byte RomBanks; - private byte[] BiosRom; + private readonly byte RomBanks; + private readonly byte[] BiosRom; // Machine resources public Z80A Cpu; @@ -241,7 +241,7 @@ namespace BizHawk.Emulation.Cores.Sega.MasterSystem public bool IsGameGear_C { get; set; } public bool IsSG1000 { get; set; } - private bool HasYM2413 = false; + private readonly bool HasYM2413 = false; private bool disablePSG = false; private bool PortDEEnabled = false; private IController _controller = NullController.Instance; @@ -257,8 +257,8 @@ namespace BizHawk.Emulation.Cores.Sega.MasterSystem private byte Port3F = 0xFF; private byte PortDE = 0x00; - private byte ForceStereoByte = 0xAD; - private bool IsGame3D = false; + private readonly byte ForceStereoByte = 0xAD; + private readonly bool IsGame3D = false; // Linked Play Only public bool start_pressed; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.ModeTMS.cs b/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.ModeTMS.cs index 469c1d6147..b7bfc0c0c5 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.ModeTMS.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.ModeTMS.cs @@ -5,7 +5,7 @@ namespace BizHawk.Emulation.Cores.Sega.MasterSystem { public partial class VDP { - int[] PaletteTMS9918 = + readonly int[] PaletteTMS9918 = { unchecked((int)0xFF000000), unchecked((int)0xFF000000), diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.cs b/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.cs index 14ee00a980..fbcbf80874 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sega/SMS/VDP.cs @@ -31,10 +31,10 @@ namespace BizHawk.Emulation.Cores.Sega.MasterSystem bool HIntPending; int lineIntLinesRemaining; - SMS Sms; - VdpMode mode; + readonly SMS Sms; + readonly VdpMode mode; public DisplayType DisplayType = DisplayType.NTSC; - Z80A Cpu; + readonly Z80A Cpu; public bool SpriteLimit; public int IPeriod = 228; @@ -75,8 +75,8 @@ namespace BizHawk.Emulation.Cores.Sega.MasterSystem public int[] Palette = new int[32]; public byte[] PatternBuffer = new byte[0x8000]; - byte[] ScanlinePriorityBuffer = new byte[256]; - byte[] SpriteCollisionBuffer = new byte[256]; + readonly byte[] ScanlinePriorityBuffer = new byte[256]; + readonly byte[] SpriteCollisionBuffer = new byte[256]; static readonly byte[] SMSPalXlatTable = { 0, 85, 170, 255 }; static readonly byte[] GGPalXlatTable = { 0, 17, 34, 51, 68, 85, 102, 119, 136, 153, 170, 187, 204, 221, 238, 255 }; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.IDebuggable.cs b/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.IDebuggable.cs index 23c35591ee..594f4b52ce 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.IDebuggable.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.IDebuggable.cs @@ -51,7 +51,7 @@ namespace BizHawk.Emulation.Cores.Consoles.Sega.gpgx private LibGPGX.mem_cb ExecCallback; private LibGPGX.mem_cb ReadCallback; private LibGPGX.mem_cb WriteCallback; - private LibGPGX.CDCallback CDCallback; + private readonly LibGPGX.CDCallback CDCallback; private void InitMemCallbacks() { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.cs b/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.cs index ec06a10512..4ce577720e 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GPGX.cs @@ -150,22 +150,22 @@ namespace BizHawk.Emulation.Cores.Consoles.Sega.gpgx } } - private LibGPGX Core; - private WaterboxHost _elf; + private readonly LibGPGX Core; + private readonly WaterboxHost _elf; - private Disc[] _cds; + private readonly Disc[] _cds; private int _discIndex; - private DiscSectorReader[] _cdReaders; + private readonly DiscSectorReader[] _cdReaders; private bool _prevDiskPressed; private bool _nextDiskPressed; - byte[] _romfile; + private readonly byte[] _romfile; private bool _disposed = false; LibGPGX.load_archive_cb LoadCallback; - LibGPGX.InputData input = new LibGPGX.InputData(); + readonly LibGPGX.InputData input = new LibGPGX.InputData(); public enum ControlType { @@ -309,7 +309,7 @@ namespace BizHawk.Emulation.Cores.Consoles.Sega.gpgx } } - LibGPGX.cd_read_cb cd_callback_handle; + readonly LibGPGX.cd_read_cb cd_callback_handle; public static LibGPGX.CDData GetCDDataStruct(Disc cd) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GenDbgHlp.cs b/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GenDbgHlp.cs index 143533c7a5..41354df988 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GenDbgHlp.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sega/gpgx64/GenDbgHlp.cs @@ -42,10 +42,10 @@ namespace BizHawk.Emulation.Cores.Consoles.Sega.gpgx private IntPtr DllBase; - List SymbolsByAddr = new List(); + readonly List SymbolsByAddr = new List(); Dictionary SymbolsByName = new Dictionary(); - byte[][] data = new byte[10][]; + readonly byte[][] data = new byte[10][]; public void SaveState(int statenum) { diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sony/PS2/DobieStation.cs b/src/BizHawk.Emulation.Cores/Consoles/Sony/PS2/DobieStation.cs index efbf3f33e5..5a2ab5d8f2 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sony/PS2/DobieStation.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sony/PS2/DobieStation.cs @@ -82,7 +82,7 @@ namespace BizHawk.Emulation.Cores.Sony.PS2 } private readonly LibDobieStation.CdCallback _cdCallback; - private DiscSectorReader _disc; + private readonly DiscSectorReader _disc; private void ReadCd(ulong sector, byte* dest) { var tmp = new byte[2048]; diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.IDebuggable.cs b/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.IDebuggable.cs index 0745589e11..71218f0ec2 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.IDebuggable.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.IDebuggable.cs @@ -47,7 +47,7 @@ namespace BizHawk.Emulation.Cores.Sony.PSX return ret; } - static Dictionary CpuRegisterIndices = new Dictionary() { + static readonly Dictionary CpuRegisterIndices = new Dictionary() { { "r1", 1 }, { "r2", 2 }, { "r3", 3 }, { "r4", 4 }, { "r5", 5 }, { "r6", 6 }, { "r7", 7 }, { "r8", 8 }, { "r9", 9 }, { "r10", 10 }, { "r11", 11 }, { "r12", 12 }, { "r13", 13 }, { "r14", 14 }, { "r15", 15 }, { "r16", 16 }, { "r17", 17 }, { "r18", 18 }, { "r19", 19 }, { "r20", 20 }, { "r21", 21 }, { "r22", 22 }, { "r23", 23 }, diff --git a/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs b/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs index f3d5f33c3a..cf2d99a026 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs @@ -410,9 +410,9 @@ namespace BizHawk.Emulation.Cores.Sony.PSX OctoshockDll.ShockDisc_ReadTOC cbReadTOC; OctoshockDll.ShockDisc_ReadLBA cbReadLBA; - Action cbActivity; + readonly Action cbActivity; - public Disc Disc; + public readonly Disc Disc; public IntPtr OctoshockHandle; public void Dispose() @@ -448,7 +448,7 @@ namespace BizHawk.Emulation.Cores.Sony.PSX return OctoshockDll.SHOCK_OK; } - byte[] SectorBuffer = new byte[2448]; + readonly byte[] SectorBuffer = new byte[2448]; int ShockDisc_ReadLBA2448(IntPtr opaque, int lba, void* dst) { @@ -468,7 +468,7 @@ namespace BizHawk.Emulation.Cores.Sony.PSX } public List Discs; - List discInterfaces = new List(); + readonly List discInterfaces = new List(); DiscInterface currentDiscInterface; public DisplayType Region => SystemVidStandard == OctoshockDll.eVidStandard.PAL ? DisplayType.PAL : DisplayType.NTSC; @@ -932,7 +932,7 @@ namespace BizHawk.Emulation.Cores.Sony.PSX public System.Drawing.Size VideoProvider_Padding { get; private set; } //private short[] sbuff = new short[1454 * 2]; //this is the most ive ever seen.. don't know why. two frames worth i guess - private short[] sbuff = new short[1611 * 2]; //need this for pal + private readonly short[] sbuff = new short[1611 * 2]; //need this for pal private int sbuffcontains = 0; public void GetSamplesSync(out short[] samples, out int nsamp) diff --git a/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.IStatable.cs b/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.IStatable.cs index 69cef86083..02f0c7b69f 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.IStatable.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.IStatable.cs @@ -15,7 +15,7 @@ namespace BizHawk.Emulation.Cores.WonderSwan savebuff = new byte[BizSwan.bizswan_binstatesize(Core)]; } - JsonSerializer ser = new JsonSerializer { Formatting = Formatting.Indented }; + readonly JsonSerializer ser = new JsonSerializer { Formatting = Formatting.Indented }; [StructLayout(LayoutKind.Sequential)] class TextStateData diff --git a/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.cs b/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.cs index 84526eb571..ecdc833a4e 100644 --- a/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.cs +++ b/src/BizHawk.Emulation.Cores/Consoles/WonderSwan/WonderSwan.cs @@ -201,7 +201,7 @@ namespace BizHawk.Emulation.Cores.WonderSwan } } - private int[] vbuff = new int[224 * 144]; + private readonly int[] vbuff = new int[224 * 144]; public int[] GetVideoBuffer() => vbuff; diff --git a/src/BizHawk.Emulation.Cores/FileID.cs b/src/BizHawk.Emulation.Cores/FileID.cs index 2af7c33eb3..6f72515cc4 100644 --- a/src/BizHawk.Emulation.Cores/FileID.cs +++ b/src/BizHawk.Emulation.Cores/FileID.cs @@ -252,46 +252,46 @@ namespace BizHawk.Emulation.Cores //if you change some of the Length arguments for longer keys, please make notes about why static class SimpleMagics { - public static SimpleMagicRecord INES = new SimpleMagicRecord { Offset = 0, Key = "NES" }; - public static SimpleMagicRecord UNIF = new SimpleMagicRecord { Offset = 0, Key = "UNIF" }; + public static readonly SimpleMagicRecord INES = new SimpleMagicRecord { Offset = 0, Key = "NES" }; + public static readonly SimpleMagicRecord UNIF = new SimpleMagicRecord { Offset = 0, Key = "UNIF" }; public static SimpleMagicRecord NSF = new SimpleMagicRecord { Offset = 0, Key = "NESM\x1A" }; - public static SimpleMagicRecord FDS_HEADERLESS = new SimpleMagicRecord { Offset = 0, Key = "\x01*NINTENDO-HVC*" }; - public static SimpleMagicRecord FDS_HEADER = new SimpleMagicRecord { Offset = 0, Key = "FDS\x1A" }; + public static readonly SimpleMagicRecord FDS_HEADERLESS = new SimpleMagicRecord { Offset = 0, Key = "\x01*NINTENDO-HVC*" }; + public static readonly SimpleMagicRecord FDS_HEADER = new SimpleMagicRecord { Offset = 0, Key = "FDS\x1A" }; //the GBA nintendo logo.. we'll only use 16 bytes of it but theyre all here, for reference //we cant expect these roms to be normally sized, but we may be able to find other features of the header to use for extra checks - public static SimpleMagicRecord GBA = new SimpleMagicRecord { Offset = 4, Length = 16, Key = "\x24\xFF\xAE\x51\x69\x9A\xA2\x21\x3D\x84\x82\x0A\x84\xE4\x09\xAD\x11\x24\x8B\x98\xC0\x81\x7F\x21\xA3\x52\xBE\x19\x93\x09\xCE\x20\x10\x46\x4A\x4A\xF8\x27\x31\xEC\x58\xC7\xE8\x33\x82\xE3\xCE\xBF\x85\xF4\xDF\x94\xCE\x4B\x09\xC1\x94\x56\x8A\xC0\x13\x72\xA7\xFC\x9F\x84\x4D\x73\xA3\xCA\x9A\x61\x58\x97\xA3\x27\xFC\x03\x98\x76\x23\x1D\xC7\x61\x03\x04\xAE\x56\xBF\x38\x84\x00\x40\xA7\x0E\xFD\xFF\x52\xFE\x03\x6F\x95\x30\xF1\x97\xFB\xC0\x85\x60\xD6\x80\x25\xA9\x63\xBE\x03\x01\x4E\x38\xE2\xF9\xA2\x34\xFF\xBB\x3E\x03\x44\x78\x00\x90\xCB\x88\x11\x3A\x94\x65\xC0\x7C\x63\x87\xF0\x3C\xAF\xD6\x25\xE4\x8B\x38\x0A\xAC\x72\x21\xD4\xF8\x07" }; - public static SimpleMagicRecord NDS = new SimpleMagicRecord { Offset = 0xC0, Length = 16, Key = "\x24\xFF\xAE\x51\x69\x9A\xA2\x21\x3D\x84\x82\x0A\x84\xE4\x09\xAD\x11\x24\x8B\x98\xC0\x81\x7F\x21\xA3\x52\xBE\x19\x93\x09\xCE\x20\x10\x46\x4A\x4A\xF8\x27\x31\xEC\x58\xC7\xE8\x33\x82\xE3\xCE\xBF\x85\xF4\xDF\x94\xCE\x4B\x09\xC1\x94\x56\x8A\xC0\x13\x72\xA7\xFC\x9F\x84\x4D\x73\xA3\xCA\x9A\x61\x58\x97\xA3\x27\xFC\x03\x98\x76\x23\x1D\xC7\x61\x03\x04\xAE\x56\xBF\x38\x84\x00\x40\xA7\x0E\xFD\xFF\x52\xFE\x03\x6F\x95\x30\xF1\x97\xFB\xC0\x85\x60\xD6\x80\x25\xA9\x63\xBE\x03\x01\x4E\x38\xE2\xF9\xA2\x34\xFF\xBB\x3E\x03\x44\x78\x00\x90\xCB\x88\x11\x3A\x94\x65\xC0\x7C\x63\x87\xF0\x3C\xAF\xD6\x25\xE4\x8B\x38\x0A\xAC\x72\x21\xD4\xF8\x07" }; + public static readonly SimpleMagicRecord GBA = new SimpleMagicRecord { Offset = 4, Length = 16, Key = "\x24\xFF\xAE\x51\x69\x9A\xA2\x21\x3D\x84\x82\x0A\x84\xE4\x09\xAD\x11\x24\x8B\x98\xC0\x81\x7F\x21\xA3\x52\xBE\x19\x93\x09\xCE\x20\x10\x46\x4A\x4A\xF8\x27\x31\xEC\x58\xC7\xE8\x33\x82\xE3\xCE\xBF\x85\xF4\xDF\x94\xCE\x4B\x09\xC1\x94\x56\x8A\xC0\x13\x72\xA7\xFC\x9F\x84\x4D\x73\xA3\xCA\x9A\x61\x58\x97\xA3\x27\xFC\x03\x98\x76\x23\x1D\xC7\x61\x03\x04\xAE\x56\xBF\x38\x84\x00\x40\xA7\x0E\xFD\xFF\x52\xFE\x03\x6F\x95\x30\xF1\x97\xFB\xC0\x85\x60\xD6\x80\x25\xA9\x63\xBE\x03\x01\x4E\x38\xE2\xF9\xA2\x34\xFF\xBB\x3E\x03\x44\x78\x00\x90\xCB\x88\x11\x3A\x94\x65\xC0\x7C\x63\x87\xF0\x3C\xAF\xD6\x25\xE4\x8B\x38\x0A\xAC\x72\x21\xD4\xF8\x07" }; + public static readonly SimpleMagicRecord NDS = new SimpleMagicRecord { Offset = 0xC0, Length = 16, Key = "\x24\xFF\xAE\x51\x69\x9A\xA2\x21\x3D\x84\x82\x0A\x84\xE4\x09\xAD\x11\x24\x8B\x98\xC0\x81\x7F\x21\xA3\x52\xBE\x19\x93\x09\xCE\x20\x10\x46\x4A\x4A\xF8\x27\x31\xEC\x58\xC7\xE8\x33\x82\xE3\xCE\xBF\x85\xF4\xDF\x94\xCE\x4B\x09\xC1\x94\x56\x8A\xC0\x13\x72\xA7\xFC\x9F\x84\x4D\x73\xA3\xCA\x9A\x61\x58\x97\xA3\x27\xFC\x03\x98\x76\x23\x1D\xC7\x61\x03\x04\xAE\x56\xBF\x38\x84\x00\x40\xA7\x0E\xFD\xFF\x52\xFE\x03\x6F\x95\x30\xF1\x97\xFB\xC0\x85\x60\xD6\x80\x25\xA9\x63\xBE\x03\x01\x4E\x38\xE2\xF9\xA2\x34\xFF\xBB\x3E\x03\x44\x78\x00\x90\xCB\x88\x11\x3A\x94\x65\xC0\x7C\x63\x87\xF0\x3C\xAF\xD6\x25\xE4\x8B\x38\x0A\xAC\x72\x21\xD4\xF8\x07" }; - public static SimpleMagicRecord GB = new SimpleMagicRecord { Offset=0x104, Length = 16, Key = "\xCE\xED\x66\x66\xCC\x0D\x00\x0B\x03\x73\x00\x83\x00\x0C\x00\x0D\x00\x08\x11\x1F\x88\x89\x00\x0E\xDC\xCC\x6E\xE6\xDD\xDD\xD9\x99\xBB\xBB\x67\x63\x6E\x0E\xEC\xCC\xDD\xDC\x99\x9F\xBB\xB9\x33\x3E" }; + public static readonly SimpleMagicRecord GB = new SimpleMagicRecord { Offset=0x104, Length = 16, Key = "\xCE\xED\x66\x66\xCC\x0D\x00\x0B\x03\x73\x00\x83\x00\x0C\x00\x0D\x00\x08\x11\x1F\x88\x89\x00\x0E\xDC\xCC\x6E\xE6\xDD\xDD\xD9\x99\xBB\xBB\x67\x63\x6E\x0E\xEC\xCC\xDD\xDC\x99\x9F\xBB\xB9\x33\x3E" }; - public static SimpleMagicRecord S32X = new SimpleMagicRecord { Offset = 0x100, Key = "SEGA 32X" }; + public static readonly SimpleMagicRecord S32X = new SimpleMagicRecord { Offset = 0x100, Key = "SEGA 32X" }; - public static SimpleMagicRecord SEGAGENESIS = new SimpleMagicRecord { Offset = 0x100, Key = "SEGA GENESIS" }; - public static SimpleMagicRecord SEGAMEGADRIVE = new SimpleMagicRecord { Offset = 0x100, Key = "SEGA MEGA DRIVE" }; - public static SimpleMagicRecord SEGASATURN = new SimpleMagicRecord { Offset = 0, Key = "SEGA SEGASATURN" }; - public static SimpleMagicRecord SEGADISCSYSTEM = new SimpleMagicRecord { Offset = 0, Key = "SEGADISCSYSTEM" }; + public static readonly SimpleMagicRecord SEGAGENESIS = new SimpleMagicRecord { Offset = 0x100, Key = "SEGA GENESIS" }; + public static readonly SimpleMagicRecord SEGAMEGADRIVE = new SimpleMagicRecord { Offset = 0x100, Key = "SEGA MEGA DRIVE" }; + public static readonly SimpleMagicRecord SEGASATURN = new SimpleMagicRecord { Offset = 0, Key = "SEGA SEGASATURN" }; + public static readonly SimpleMagicRecord SEGADISCSYSTEM = new SimpleMagicRecord { Offset = 0, Key = "SEGADISCSYSTEM" }; - public static SimpleMagicRecord PSX = new SimpleMagicRecord { Offset = 0x24E0, Key = " Licensed by Sony Computer Entertainment" }; //there might be other ideas for checking in mednafen sources, if we need them - public static SimpleMagicRecord PSX_EXE = new SimpleMagicRecord { Key = "PS-X EXE\0" }; - public static SimpleMagicRecord PSP = new SimpleMagicRecord { Offset = 0x8000, Key = "\x01CD001\x01\0x00PSP GAME" }; - public static SimpleMagicRecord PSF = new SimpleMagicRecord { Offset = 0, Key = "PSF\x1" }; + public static readonly SimpleMagicRecord PSX = new SimpleMagicRecord { Offset = 0x24E0, Key = " Licensed by Sony Computer Entertainment" }; //there might be other ideas for checking in mednafen sources, if we need them + public static readonly SimpleMagicRecord PSX_EXE = new SimpleMagicRecord { Key = "PS-X EXE\0" }; + public static readonly SimpleMagicRecord PSP = new SimpleMagicRecord { Offset = 0x8000, Key = "\x01CD001\x01\0x00PSP GAME" }; + public static readonly SimpleMagicRecord PSF = new SimpleMagicRecord { Offset = 0, Key = "PSF\x1" }; //https://sites.google.com/site/atari7800wiki/a78-header - public static SimpleMagicRecord A78 = new SimpleMagicRecord { Offset = 0, Key = "\x01ATARI7800" }; + public static readonly SimpleMagicRecord A78 = new SimpleMagicRecord { Offset = 0, Key = "\x01ATARI7800" }; //could be at various offsets? public static SimpleMagicRecord TMR_SEGA = new SimpleMagicRecord { Offset = 0x7FF0, Key = "TMR SEGA" }; - public static SimpleMagicRecord SBI = new SimpleMagicRecord { Key = "SBI\0" }; - public static SimpleMagicRecord M3U = new SimpleMagicRecord { Key = "#EXTM3U" }; //note: M3U may not have this. EXTM3U only has it. We'll still catch it by extension though. + public static readonly SimpleMagicRecord SBI = new SimpleMagicRecord { Key = "SBI\0" }; + public static readonly SimpleMagicRecord M3U = new SimpleMagicRecord { Key = "#EXTM3U" }; //note: M3U may not have this. EXTM3U only has it. We'll still catch it by extension though. - public static SimpleMagicRecord ECM = new SimpleMagicRecord { Key = "ECM\0" }; - public static SimpleMagicRecord FLAC = new SimpleMagicRecord { Key = "fLaC" }; - public static SimpleMagicRecord MPC = new SimpleMagicRecord { Key = "MP+", ExtraCheck = (s) => { s.Position += 3; return s.ReadByte() >= 7; } }; - public static SimpleMagicRecord APE = new SimpleMagicRecord { Key = "MAC " }; - public static SimpleMagicRecord[] WAV = { + public static readonly SimpleMagicRecord ECM = new SimpleMagicRecord { Key = "ECM\0" }; + public static readonly SimpleMagicRecord FLAC = new SimpleMagicRecord { Key = "fLaC" }; + public static readonly SimpleMagicRecord MPC = new SimpleMagicRecord { Key = "MP+", ExtraCheck = (s) => { s.Position += 3; return s.ReadByte() >= 7; } }; + public static readonly SimpleMagicRecord APE = new SimpleMagicRecord { Key = "MAC " }; + public static readonly SimpleMagicRecord[] WAV = { new SimpleMagicRecord { Offset = 0, Key = "RIFF" }, new SimpleMagicRecord { Offset = 8, Key = "WAVEfmt " } }; @@ -307,14 +307,14 @@ namespace BizHawk.Emulation.Cores DefaultForExtension = defaultForExtension; } - public FileIDType DefaultForExtension; - public List Testers; + public readonly FileIDType DefaultForExtension; + public readonly List Testers; } /// /// testers to try for each extension, along with a default for the extension /// - static Dictionary ExtensionHandlers = new Dictionary { + static readonly Dictionary ExtensionHandlers = new Dictionary { { "NES", new ExtensionInfo(FileIDType.INES, Test_INES ) }, { "FDS", new ExtensionInfo(FileIDType.FDS, Test_FDS ) }, { "GBA", new ExtensionInfo(FileIDType.GBA, (j)=>Test_Simple(j,FileIDType.GBA,SimpleMagics.GBA) ) }, @@ -383,7 +383,7 @@ namespace BizHawk.Emulation.Cores delegate FileIDResult FormatTester(IdentifyJob job); - static int[] no_offsets = { 0 }; + static readonly int[] no_offsets = { 0 }; /// /// checks for the magic string (bytewise ASCII check) at the given address diff --git a/src/BizHawk.Emulation.Cores/Libretro/LibretroApi.cs b/src/BizHawk.Emulation.Cores/Libretro/LibretroApi.cs index da65c49879..b34c8ca2ef 100644 --- a/src/BizHawk.Emulation.Cores/Libretro/LibretroApi.cs +++ b/src/BizHawk.Emulation.Cores/Libretro/LibretroApi.cs @@ -11,7 +11,7 @@ namespace BizHawk.Emulation.Cores.Libretro { public unsafe partial class LibretroApi : IDisposable { - InstanceDll instanceDll, instanceDllCore; + readonly InstanceDll instanceDll, instanceDllCore; string InstanceName; //YUCK @@ -33,9 +33,9 @@ namespace BizHawk.Emulation.Cores.Libretro //however -- i need to merge the API and the core. theyre too closely related public CommStruct* comm; - MessageApi Message; - BufferApi _copyBuffer; //TODO: consider making private and wrapping - BufferApi _setBuffer; //TODO: consider making private and wrapping + readonly MessageApi Message; + readonly BufferApi _copyBuffer; //TODO: consider making private and wrapping + readonly BufferApi _setBuffer; //TODO: consider making private and wrapping SetVariableApi SetVariable; public LibretroApi(string dllPath, string corePath) diff --git a/src/BizHawk.Emulation.Cores/Libretro/LibretroCore.cs b/src/BizHawk.Emulation.Cores/Libretro/LibretroCore.cs index ffe0cc5515..b3207ad248 100644 --- a/src/BizHawk.Emulation.Cores/Libretro/LibretroCore.cs +++ b/src/BizHawk.Emulation.Cores/Libretro/LibretroCore.cs @@ -18,7 +18,7 @@ namespace BizHawk.Emulation.Cores.Libretro public unsafe partial class LibretroCore : IEmulator, ISettable, ISaveRam, IStatable, IVideoProvider, IInputPollable { - private LibretroApi api; + private readonly LibretroApi api; // TODO: codepath just for introspection (lighter weight; no speex, no controls, etc.) public LibretroCore(CoreComm nextComm, IGameInfo game, string corePath) diff --git a/src/BizHawk.Emulation.Cores/Sound/DualSyncSound.cs b/src/BizHawk.Emulation.Cores/Sound/DualSyncSound.cs index 7cd8d9801a..5974f33a87 100644 --- a/src/BizHawk.Emulation.Cores/Sound/DualSyncSound.cs +++ b/src/BizHawk.Emulation.Cores/Sound/DualSyncSound.cs @@ -8,14 +8,14 @@ namespace BizHawk.Emulation.Cores.Sound /// public class DualSyncSound : ISoundProvider { - private ISoundProvider _left; - private ISoundProvider _right; + private readonly ISoundProvider _left; + private readonly ISoundProvider _right; private int _nsamp; private short[] _samp = new short[0]; - private short[] _leftOverflow = new short[32]; + private readonly short[] _leftOverflow = new short[32]; private int _leftOverflowCount = 0; - private short[] _rightOverflow = new short[32]; + private readonly short[] _rightOverflow = new short[32]; private int _rightOverflowCount = 0; diff --git a/src/BizHawk.Emulation.Cores/Sound/OneBitBeeper.cs b/src/BizHawk.Emulation.Cores/Sound/OneBitBeeper.cs index b62d6760a6..a70d7e9d8b 100644 --- a/src/BizHawk.Emulation.Cores/Sound/OneBitBeeper.cs +++ b/src/BizHawk.Emulation.Cores/Sound/OneBitBeeper.cs @@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Sound private int _sampleRate; private int _clocksPerFrame; private int _framesPerSecond; - private BlipBuffer _blip; + private readonly BlipBuffer _blip; private readonly string _beeperId; /// diff --git a/src/BizHawk.Emulation.Cores/Sound/SyncSoundMixer.cs b/src/BizHawk.Emulation.Cores/Sound/SyncSoundMixer.cs index e060d6750b..9ce1c1ae09 100644 --- a/src/BizHawk.Emulation.Cores/Sound/SyncSoundMixer.cs +++ b/src/BizHawk.Emulation.Cores/Sound/SyncSoundMixer.cs @@ -58,7 +58,7 @@ namespace BizHawk.Emulation.Cores.Components /// 882 - 44100KHz - 50Hz /// 735 - 44100Khz - 60Hz /// - private int? _targetSampleCount; + private readonly int? _targetSampleCount; /// /// Constructor diff --git a/src/BizHawk.Emulation.Cores/Sound/VRC6Alt.cs b/src/BizHawk.Emulation.Cores/Sound/VRC6Alt.cs index ac6c0ca789..5cf4c495cf 100644 --- a/src/BizHawk.Emulation.Cores/Sound/VRC6Alt.cs +++ b/src/BizHawk.Emulation.Cores/Sound/VRC6Alt.cs @@ -9,10 +9,10 @@ namespace BizHawk.Emulation.Cores.Components { // http://wiki.nesdev.com/w/index.php/VRC6_audio - Pulse pulse1, pulse2; - Saw saw; + readonly Pulse pulse1, pulse2; + readonly Saw saw; - Action enqueuer; + readonly Action enqueuer; /// a place to dump deltas to public VRC6Alt(Action enqueuer) @@ -91,7 +91,7 @@ namespace BizHawk.Emulation.Cores.Components class Saw { - Action SendDiff; + readonly Action SendDiff; public Saw(Action SendDiff) { this.SendDiff = SendDiff; } // set by regs @@ -190,7 +190,7 @@ namespace BizHawk.Emulation.Cores.Components class Pulse { - Action SendDiff; + readonly Action SendDiff; public Pulse(Action SendDiff) { this.SendDiff = SendDiff; } // set by regs diff --git a/src/BizHawk.Emulation.Cores/Sound/YM2413.cs b/src/BizHawk.Emulation.Cores/Sound/YM2413.cs index 80bf9b75c5..44a1bc8479 100644 --- a/src/BizHawk.Emulation.Cores/Sound/YM2413.cs +++ b/src/BizHawk.Emulation.Cores/Sound/YM2413.cs @@ -83,7 +83,7 @@ namespace BizHawk.Emulation.Cores.Components const int OPLL_TONE_NUM = 3; - static byte[][] default_inst = new byte[3][] { + static readonly byte[][] default_inst = new byte[3][] { new byte[] { 0x49,0x4c,0x4c,0x32,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, 0x61,0x61,0x1E,0x17,0xF0,0x7F,0x00,0x17,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, @@ -269,43 +269,43 @@ namespace BizHawk.Emulation.Cores.Components static uint rate = 3354932; /* WaveTable for each envelope amp */ - static short[] fullsintable = new short[PG_WIDTH]; - static short[] halfsintable = new short[PG_WIDTH]; + static readonly short[] fullsintable = new short[PG_WIDTH]; + static readonly short[] halfsintable = new short[PG_WIDTH]; /* LFO Table */ - static int[] pmtable = new int[PM_PG_WIDTH]; - static int[] amtable = new int[AM_PG_WIDTH]; + static readonly int[] pmtable = new int[PM_PG_WIDTH]; + static readonly int[] amtable = new int[AM_PG_WIDTH]; /* Phase delta for LFO */ static uint pm_dphase; static uint am_dphase; /* dB to Liner table */ - static short[] DB2LIN_TABLE = new short[(DB_MUTE + DB_MUTE) * 2]; + static readonly short[] DB2LIN_TABLE = new short[(DB_MUTE + DB_MUTE) * 2]; /* Liner to Log curve conversion table (for Attack rate). */ - static short[] AR_ADJUST_TABLE = new short[1 << EG_BITS]; + static readonly short[] AR_ADJUST_TABLE = new short[1 << EG_BITS]; /* Empty voice data */ //static OPLL_PATCH null_patch = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; /* Basic voice Data */ - static OPLL_PATCH[,] default_patch = new OPLL_PATCH[OPLL_TONE_NUM, (16 + 3) * 2]; + static readonly OPLL_PATCH[,] default_patch = new OPLL_PATCH[OPLL_TONE_NUM, (16 + 3) * 2]; /* Definition of envelope mode */ public enum OPLL_EG_STATE { READY, ATTACK, DECAY, SUSHOLD, SUSTINE, RELEASE, SETTLE, FINISH } /* Phase incr table for Attack */ - static uint[,] dphaseARTable = new uint[16, 16]; + static readonly uint[,] dphaseARTable = new uint[16, 16]; /* Phase incr table for Decay and Release */ - static uint[,] dphaseDRTable = new uint[16, 16]; + static readonly uint[,] dphaseDRTable = new uint[16, 16]; /* KSL + TL Table */ - static uint[, , ,] tllTable = new uint[16, 8, 1 << TL_BITS, 4]; - static int[, ,] rksTable = new int[2, 8, 2]; + static readonly uint[, , ,] tllTable = new uint[16, 8, 1 << TL_BITS, 4]; + static readonly int[, ,] rksTable = new int[2, 8, 2]; /* Phase incr table for PG */ - static uint[, ,] dphaseTable = new uint[512, 8, 16]; + static readonly uint[, ,] dphaseTable = new uint[512, 8, 16]; /*************************************************** @@ -1104,7 +1104,7 @@ namespace BizHawk.Emulation.Cores.Components /* EG */ static uint S2E(double x) { return (SL2EG((uint)(x / SL_STEP)) << (EG_DP_BITS - EG_BITS)); } - static uint[] SL = + static readonly uint[] SL = { S2E (0.0), S2E (3.0), S2E (6.0), S2E (9.0), S2E (12.0), S2E (15.0), S2E (18.0), S2E (21.0), S2E (24.0), S2E (27.0), S2E (30.0), S2E (33.0), S2E (36.0), S2E (39.0), S2E (42.0), S2E (48.0) diff --git a/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Controller.cs b/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Controller.cs index 18c6c9316b..02a0e3c836 100644 --- a/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Controller.cs +++ b/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Controller.cs @@ -270,7 +270,7 @@ namespace BizHawk.Emulation.Cores.Waterbox _switchPreviousFrame = switchPreviousFrame.ToArray(); } - private byte[] _switchPreviousFrame; + private readonly byte[] _switchPreviousFrame; private readonly List> _thunks = new List>(); diff --git a/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.ComponentModel.cs b/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.ComponentModel.cs index fbaf099b42..aab255f08e 100644 --- a/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.ComponentModel.cs +++ b/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.ComponentModel.cs @@ -81,7 +81,7 @@ namespace BizHawk.Emulation.Cores.Waterbox public abstract class MednaPropertyDescriptor : PropertyDescriptor { public SettingT Setting { get; private set; } - private bool _isSyncSetting; + private readonly bool _isSyncSetting; public MednaPropertyDescriptor(SettingT setting, bool isSyncSetting) : base(setting.SettingsKey, new Attribute[0]) { diff --git a/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.cs b/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.cs index 7c9ec9f69f..88084d58f7 100644 --- a/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.cs +++ b/src/BizHawk.Emulation.Cores/Waterbox/NymaCore.Settings.cs @@ -19,7 +19,7 @@ namespace BizHawk.Emulation.Cores.Waterbox /// /// What this core was actually started with /// - private NymaSyncSettings _syncSettingsActual; + private readonly NymaSyncSettings _syncSettingsActual; public NymaSettings GetSettings() { var ret = _settings.Clone(); @@ -300,12 +300,12 @@ namespace BizHawk.Emulation.Cores.Waterbox SettingsInfo = s; } - private static IReadOnlyDictionary ExtraOverrides = new Dictionary + private static readonly IReadOnlyDictionary ExtraOverrides = new Dictionary { { "nyma.constantfb", new SettingOverride { NonSync = true, NoRestart = true } }, }; - private static IReadOnlyCollection ExtraSettings = new List + private static readonly IReadOnlyCollection ExtraSettings = new List { new SettingT { diff --git a/src/BizHawk.Emulation.Cores/Waterbox/WaterboxCore.cs b/src/BizHawk.Emulation.Cores/Waterbox/WaterboxCore.cs index 80eecb953e..8ad1dc1bbc 100644 --- a/src/BizHawk.Emulation.Cores/Waterbox/WaterboxCore.cs +++ b/src/BizHawk.Emulation.Cores/Waterbox/WaterboxCore.cs @@ -15,7 +15,7 @@ namespace BizHawk.Emulation.Cores.Waterbox private LibWaterboxCore _core; protected WaterboxHost _exe; protected LibWaterboxCore.MemoryArea[] _memoryAreas; - private LibWaterboxCore.EmptyCallback _inputCallback; + private readonly LibWaterboxCore.EmptyCallback _inputCallback; protected CoreComm CoreComm { get; } public class Configuration diff --git a/src/BizHawk.Emulation.DiscSystem/API_MednaDisc.cs b/src/BizHawk.Emulation.DiscSystem/API_MednaDisc.cs index 43b6579a0d..4861442c24 100644 --- a/src/BizHawk.Emulation.DiscSystem/API_MednaDisc.cs +++ b/src/BizHawk.Emulation.DiscSystem/API_MednaDisc.cs @@ -31,7 +31,7 @@ namespace BizHawk.Emulation.DiscSystem //leave the disc open until this is disposed so we can read sectors from it } - private IntPtr handle; + private readonly IntPtr handle; public MednadiscTOC TOC; public MednadiscTOCTrack[] TOCTracks; diff --git a/src/BizHawk.Emulation.DiscSystem/CDFS/EndianBitConverter.cs b/src/BizHawk.Emulation.DiscSystem/CDFS/EndianBitConverter.cs index 5b7172ac2c..f754ca5676 100644 --- a/src/BizHawk.Emulation.DiscSystem/CDFS/EndianBitConverter.cs +++ b/src/BizHawk.Emulation.DiscSystem/CDFS/EndianBitConverter.cs @@ -31,7 +31,7 @@ namespace BizHawk.Emulation.DiscSystem /// /// Keep track of whether we need to swap the bytes or not /// - private bool swap; + private readonly bool swap; /// /// Create the converter with the given endian-ness. diff --git a/src/BizHawk.Emulation.DiscSystem/CDFS/ISOVolumeDescriptor.cs b/src/BizHawk.Emulation.DiscSystem/CDFS/ISOVolumeDescriptor.cs index cc9e4dba21..ed831b7a7f 100644 --- a/src/BizHawk.Emulation.DiscSystem/CDFS/ISOVolumeDescriptor.cs +++ b/src/BizHawk.Emulation.DiscSystem/CDFS/ISOVolumeDescriptor.cs @@ -23,8 +23,8 @@ namespace BizHawk.Emulation.DiscSystem private const int LENGTH_TIME = 17; private const int LENGTH_RESERVED = 512; - private EndianBitConverter bc = EndianBitConverter.CreateForLittleEndian(); - private EndianBitConverter bcBig = EndianBitConverter.CreateForBigEndian(); + private readonly EndianBitConverter bc = EndianBitConverter.CreateForLittleEndian(); + private readonly EndianBitConverter bcBig = EndianBitConverter.CreateForBigEndian(); /// /// The type of this volume description, only 1 and 255 are supported diff --git a/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_WaveFile.cs b/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_WaveFile.cs index 90c147b8a7..c7a3ac2242 100644 --- a/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_WaveFile.cs +++ b/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_WaveFile.cs @@ -40,7 +40,7 @@ namespace BizHawk.Emulation.DiscSystem private string physicalPath; private long length; - public long Offset = 0; + public readonly long Offset = 0; private BufferedStream fs; public void Dispose() diff --git a/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_ZeroPadAdapter.cs b/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_ZeroPadAdapter.cs index 0807d3b5d1..c681b14f91 100644 --- a/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_ZeroPadAdapter.cs +++ b/src/BizHawk.Emulation.DiscSystem/DiscFormats/Blobs/Blob_ZeroPadAdapter.cs @@ -8,8 +8,8 @@ namespace BizHawk.Emulation.DiscSystem { internal sealed class Blob_ZeroPadAdapter : IBlob { - private IBlob srcBlob; - private long srcBlobLength; + private readonly IBlob srcBlob; + private readonly long srcBlobLength; public Blob_ZeroPadAdapter(IBlob srcBlob, long srcBlobLength) { this.srcBlob = srcBlob; diff --git a/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Load.cs b/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Load.cs index 97d76122c6..45ac9fe938 100644 --- a/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Load.cs +++ b/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Load.cs @@ -62,7 +62,7 @@ namespace BizHawk.Emulation.DiscSystem.CUE } private List BlobInfos; - private List TrackInfos = new List(); + private readonly List TrackInfos = new List(); private void MountBlobs() diff --git a/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Parse.cs b/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Parse.cs index 580e100f95..111aa42817 100644 --- a/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Parse.cs +++ b/src/BizHawk.Emulation.DiscSystem/DiscFormats/CUE/CUE_Parse.cs @@ -33,7 +33,7 @@ namespace BizHawk.Emulation.DiscSystem.CUE private class CueLineParser { private int index; - private string str; + private readonly string str; public bool EOF; public CueLineParser(string line) { diff --git a/src/BizHawk.Emulation.DiscSystem/DiscHasher.cs b/src/BizHawk.Emulation.DiscSystem/DiscHasher.cs index d75773ef26..a6b760bd35 100644 --- a/src/BizHawk.Emulation.DiscSystem/DiscHasher.cs +++ b/src/BizHawk.Emulation.DiscSystem/DiscHasher.cs @@ -11,7 +11,7 @@ namespace BizHawk.Emulation.DiscSystem this.disc = disc; } - private Disc disc; + private readonly Disc disc; /// /// calculates the hash for quick PSX Disc identification @@ -147,7 +147,7 @@ namespace BizHawk.Emulation.DiscSystem } } - private byte[] smallbuf = new byte[8]; + private readonly byte[] smallbuf = new byte[8]; public void Add(int data) { smallbuf[0] = (byte)((data) & 0xFF); diff --git a/src/BizHawk.Emulation.DiscSystem/DiscSectorReader.cs b/src/BizHawk.Emulation.DiscSystem/DiscSectorReader.cs index 0b3db177ac..7554434355 100644 --- a/src/BizHawk.Emulation.DiscSystem/DiscSectorReader.cs +++ b/src/BizHawk.Emulation.DiscSystem/DiscSectorReader.cs @@ -58,7 +58,7 @@ namespace BizHawk.Emulation.DiscSystem { public DiscSectorReaderPolicy Policy = new DiscSectorReaderPolicy(); - private Disc disc; + private readonly Disc disc; public DiscSectorReader(Disc disc) { @@ -297,8 +297,8 @@ namespace BizHawk.Emulation.DiscSystem } //lets not try to these as a sector cache. it gets too complicated. its just a temporary variable. - private byte[] buf2442 = new byte[2448]; - private byte[] buf12 = new byte[12]; - private SectorSynthJob job = new SectorSynthJob(); + private readonly byte[] buf2442 = new byte[2448]; + private readonly byte[] buf12 = new byte[12]; + private readonly SectorSynthJob job = new SectorSynthJob(); } } \ No newline at end of file diff --git a/src/BizHawk.Emulation.DiscSystem/DiscStream.cs b/src/BizHawk.Emulation.DiscSystem/DiscStream.cs index 467eb9e478..c2c3a3c6b9 100644 --- a/src/BizHawk.Emulation.DiscSystem/DiscStream.cs +++ b/src/BizHawk.Emulation.DiscSystem/DiscStream.cs @@ -51,14 +51,14 @@ namespace BizHawk.Emulation.DiscSystem /// public class DiscStream : System.IO.Stream { - private int SectorSize; - private int NumSectors; + private readonly int SectorSize; + private readonly int NumSectors; private Disc Disc; private long currPosition; - private byte[] cachedSectorBuffer; + private readonly byte[] cachedSectorBuffer; private int cachedSector; - private DiscSectorReader dsr; + private readonly DiscSectorReader dsr; /// is not or public DiscStream(Disc disc, EDiscStreamView view, int from_lba)