From 1dcb8e5122a60606ded2534a7db195d829356d30 Mon Sep 17 00:00:00 2001 From: "ALIENJACK\\alien" Date: Thu, 29 Aug 2024 17:30:56 +0800 Subject: [PATCH] =?UTF-8?q?=E8=A1=A5=E5=85=85State?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../Assets/VirtualNes.Core/State/DISKDATA.cs | 12 +++++- .../Assets/VirtualNes.Core/State/EXCTRSTAT.cs | 2 +- .../Assets/VirtualNes.Core/State/FILEHDR2.cs | 5 ++- .../Assets/VirtualNes.Core/State/State.cs | 39 +++++++++++++++++++ 4 files changed, 54 insertions(+), 4 deletions(-) diff --git a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/DISKDATA.cs b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/DISKDATA.cs index 9ff4b228..95e21b60 100644 --- a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/DISKDATA.cs +++ b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/DISKDATA.cs @@ -1,7 +1,17 @@ namespace VirtualNes.Core { - public struct DISKDATA + public struct DISKDATA : IStateBufferObject { public int DifferentSize; + + public uint GetSize() + { + return sizeof(int); + } + + public void SaveState(StateBuffer buffer) + { + buffer.Write(DifferentSize); + } } } diff --git a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/EXCTRSTAT.cs b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/EXCTRSTAT.cs index 8351127d..469c4141 100644 --- a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/EXCTRSTAT.cs +++ b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/EXCTRSTAT.cs @@ -11,7 +11,7 @@ public readonly void SaveState(StateBuffer buffer) { - throw new System.NotImplementedException(); + buffer.Write(data); } } } diff --git a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/FILEHDR2.cs b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/FILEHDR2.cs index b8c62fbc..46dc2097 100644 --- a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/FILEHDR2.cs +++ b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/FILEHDR2.cs @@ -16,15 +16,16 @@ namespace VirtualNes.Core /// 2字节 public ushort Ext2; - public void SaveState(StateBuffer buffer) + public readonly void SaveState(StateBuffer buffer) { buffer.Write(ID); buffer.Write(BlockVersion); + buffer.Write(Ext0); buffer.Write(Ext1); buffer.Write(Ext2); } - public uint GetSize() + public readonly uint GetSize() { return (uint)(ID.Length + sizeof(ushort) + sizeof(uint) + sizeof(ushort) + sizeof(ushort)); } diff --git a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/State.cs b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/State.cs index 2edd3fb6..d1f5ddb4 100644 --- a/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/State.cs +++ b/AxibugEmuOnline.Client/Assets/VirtualNes.Core/State/State.cs @@ -35,5 +35,44 @@ namespace VirtualNes.Core public BLOCKHDR exctrBLOCK; public EXCTRSTAT exctr; + + public readonly byte[] ToBytes() + { + StateBuffer buffer = new StateBuffer(); + + HEADER.SaveState(buffer); + + regBLOCK.SaveState(buffer); + reg.SaveState(buffer); + + ramBLOCK.SaveState(buffer); + ram.SaveState(buffer); + + if(WRAM!=null) buffer.Write(WRAM); + + mmuBLOCK.SaveState(buffer); + mmu.SaveState(buffer); + buffer.Write(CPU_MEM_BANK.ToArray()); + buffer.Write(VRAM); + buffer.Write(CRAM.ToArray()); + + mmcBLOCK.SaveState(buffer); + mmc.SaveState(buffer); + + ctrBLOCK.SaveState(buffer); + ctr.SaveState(buffer); + + sndBLOCK.SaveState(buffer); + snd.SaveState(buffer); + + dskBLOCK.SaveState(buffer); + dsk.SaveState(buffer); + buffer.Write(dskdata); + + exctrBLOCK.SaveState(buffer); + exctr.SaveState(buffer); + + return buffer.Data.ToArray(); + } } }