//////////////////////////////////////////////////////////////////////////
// Mapper015  100-in-1 chip                                             //
//////////////////////////////////////////////////////////////////////////
using static VirtualNes.MMU;
using static VirtualNes.Core.CPU;
using INT = System.Int32;
using BYTE = System.Byte;
//using Codice.CM.Client.Differences;

namespace VirtualNes.Core
{
	public class Mapper015 : Mapper
	{

		public Mapper015(NES parent) : base(parent) { }

		public override void Reset()
		{
			SetPROM_32K_Bank(0, 1, 2, 3);
		}

		//void Mapper015::Write(WORD addr, BYTE data)
		public override void Write(ushort addr, byte data)
		{
			switch (addr)
			{
				case 0x8000:
					if ((data & 0x80) != 0)
					{
						SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 1);
						SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 0);
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 3);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 2);
					}
					else
					{
						SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 0);
						SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 1);
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 2);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 3);
					}
					if ((data & 0x40) != 0)
						SetVRAM_Mirror(VRAM_HMIRROR);
					else SetVRAM_Mirror(VRAM_VMIRROR);
					break;
				case 0x8001:
					if ((data & 0x80) != 0)
					{
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 1);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 0);
					}
					else
					{
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 0);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 1);
					}
					break;
				case 0x8002:
					if ((data & 0x80) != 0)
					{
						SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 1);
						SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 1);
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 1);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 1);
					}
					else
					{
						SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 0);
						SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 0);
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 0);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 0);
					}
					break;
				case 0x8003:
					if ((data & 0x80) != 0)
					{
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 1);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 0);
					}
					else
					{
						SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 0);
						SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 1);
					}
					if ((data & 0x40) != 0) SetVRAM_Mirror(VRAM_HMIRROR);
					else SetVRAM_Mirror(VRAM_VMIRROR);
					break;
			}
		}


	}
}