mirror of
https://github.com/MoleskiCoder/EightBitNet.git
synced 2025-01-23 07:30:46 +00:00
Remove need to check object validity in LR35902 fuse tests.
Signed-off-by: Adrian Conlon <Adrian.conlon@gmail.com>
This commit is contained in:
parent
6a883a6252
commit
e4a0aaedc4
@ -9,29 +9,27 @@
|
||||
private readonly TestEvents events = new TestEvents();
|
||||
private readonly List<MemoryDatum> memoryData = new List<MemoryDatum>();
|
||||
|
||||
public bool Valid => !string.IsNullOrEmpty(this.Description);
|
||||
|
||||
public string Description { get; private set; }
|
||||
|
||||
public RegisterState RegisterState { get; } = new RegisterState();
|
||||
|
||||
public ReadOnlyCollection<MemoryDatum> MemoryData => this.memoryData.AsReadOnly();
|
||||
|
||||
public void Parse(Lines lines)
|
||||
public bool TryParse(Lines lines)
|
||||
{
|
||||
if (lines == null)
|
||||
{
|
||||
throw new ArgumentNullException(nameof(lines));
|
||||
}
|
||||
|
||||
while (!lines.EndOfFile && !this.Valid)
|
||||
while (!lines.EndOfFile && string.IsNullOrWhiteSpace(this.Description))
|
||||
{
|
||||
this.Description = lines.ReadLine();
|
||||
}
|
||||
|
||||
if (!this.Valid)
|
||||
if (string.IsNullOrWhiteSpace(this.Description))
|
||||
{
|
||||
return;
|
||||
return false;
|
||||
}
|
||||
|
||||
this.events.Parse(lines);
|
||||
@ -50,6 +48,8 @@
|
||||
}
|
||||
}
|
||||
while (!finished);
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -17,8 +17,7 @@
|
||||
while (!this.lines.EndOfFile)
|
||||
{
|
||||
var result = new Result();
|
||||
result.Parse(this.lines);
|
||||
if (result.Valid)
|
||||
if (result.TryParse(this.lines))
|
||||
{
|
||||
this.Container.Add(result.Description, result);
|
||||
}
|
||||
|
@ -5,9 +5,7 @@
|
||||
|
||||
public class Test
|
||||
{
|
||||
private List<MemoryDatum> memoryData = new List<MemoryDatum>();
|
||||
|
||||
public bool Valid => !string.IsNullOrEmpty(this.Description);
|
||||
private readonly List<MemoryDatum> memoryData = new List<MemoryDatum>();
|
||||
|
||||
public string Description { get; private set; }
|
||||
|
||||
@ -15,21 +13,21 @@
|
||||
|
||||
public IReadOnlyCollection<MemoryDatum> MemoryData => this.memoryData.AsReadOnly();
|
||||
|
||||
public void Parse(Lines lines)
|
||||
public bool TryParse(Lines lines)
|
||||
{
|
||||
if (lines == null)
|
||||
{
|
||||
throw new ArgumentNullException(nameof(lines));
|
||||
}
|
||||
|
||||
while (!lines.EndOfFile && !this.Valid)
|
||||
while (!lines.EndOfFile && string.IsNullOrEmpty(this.Description))
|
||||
{
|
||||
this.Description = lines.ReadLine();
|
||||
}
|
||||
|
||||
if (!this.Valid)
|
||||
if (string.IsNullOrEmpty(this.Description))
|
||||
{
|
||||
return;
|
||||
return false;
|
||||
}
|
||||
|
||||
this.RegisterState.Parse(lines);
|
||||
@ -47,6 +45,8 @@
|
||||
}
|
||||
}
|
||||
while (!finished);
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -7,8 +7,6 @@
|
||||
{
|
||||
private int cycles;
|
||||
|
||||
public bool Valid { get; private set; } = false;
|
||||
|
||||
public int Cycles => this.cycles;
|
||||
|
||||
public string Specifier { get; private set; }
|
||||
@ -17,37 +15,37 @@
|
||||
|
||||
public byte Value { get; private set; } = (byte)EightBit.Mask.Mask8;
|
||||
|
||||
public void Parse(Lines lines)
|
||||
public bool TryParse(Lines lines)
|
||||
{
|
||||
if (lines == null)
|
||||
{
|
||||
throw new ArgumentNullException(nameof(lines));
|
||||
}
|
||||
|
||||
this.ParseLine(lines.ReadLine());
|
||||
if (!this.Valid)
|
||||
var returned = this.TryParseLine(lines.ReadLine());
|
||||
if (!returned)
|
||||
{
|
||||
lines.UnreadLine();
|
||||
}
|
||||
|
||||
return returned;
|
||||
}
|
||||
|
||||
private void ParseLine(string line)
|
||||
private bool TryParseLine(string line)
|
||||
{
|
||||
var split = line.Split(new char[] { ' ', '\t' });
|
||||
this.ParseLine(split);
|
||||
return this.TryParseLine(split);
|
||||
}
|
||||
|
||||
private void ParseLine(string[] tokens)
|
||||
private bool TryParseLine(string[] tokens)
|
||||
{
|
||||
this.Valid = int.TryParse(tokens[0], out this.cycles);
|
||||
if (!this.Valid)
|
||||
if (!int.TryParse(tokens[0], out this.cycles))
|
||||
{
|
||||
return;
|
||||
return false;
|
||||
}
|
||||
|
||||
this.Specifier = tokens[1];
|
||||
|
||||
this.Valid = true;
|
||||
switch (this.Specifier)
|
||||
{
|
||||
case "MR":
|
||||
@ -68,9 +66,10 @@
|
||||
break;
|
||||
|
||||
default:
|
||||
this.Valid = false;
|
||||
break;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -11,18 +11,17 @@
|
||||
|
||||
public void Parse(Lines lines)
|
||||
{
|
||||
var complete = false;
|
||||
var success = false;
|
||||
do
|
||||
{
|
||||
var e = new TestEvent();
|
||||
e.Parse(lines);
|
||||
complete = !e.Valid;
|
||||
if (!complete)
|
||||
success = e.TryParse(lines);
|
||||
if (success)
|
||||
{
|
||||
this.container.Add(e);
|
||||
}
|
||||
}
|
||||
while (!complete);
|
||||
while (success);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -17,8 +17,7 @@
|
||||
while (!this.lines.EndOfFile)
|
||||
{
|
||||
var test = new Test();
|
||||
test.Parse(this.lines);
|
||||
if (test.Valid)
|
||||
if (test.TryParse(this.lines))
|
||||
{
|
||||
this.Container.Add(test.Description, test);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user