mirror of
https://github.com/aaru-dps/Aaru.git
synced 2025-12-16 19:24:25 +00:00
Implement IMediaGraph in Spiral.
This commit is contained in:
@@ -285,7 +285,7 @@ partial class Dump
|
||||
|
||||
imageWriteDuration += (DateTime.Now - writeStart).TotalSeconds;
|
||||
|
||||
_opticalDiscSpiral?.PaintSectorGood(i + r);
|
||||
_mediaGraph?.PaintSectorGood(i + r);
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -398,9 +398,7 @@ partial class Dump
|
||||
|
||||
imageWriteDuration += (DateTime.Now - writeStart).TotalSeconds;
|
||||
|
||||
if(_opticalDiscSpiral is not null)
|
||||
for(ulong p = 0; p < blocksToRead; p++)
|
||||
_opticalDiscSpiral?.PaintSectorGood(i + p);
|
||||
_mediaGraph?.PaintSectorsGood(i, blocksToRead);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
@@ -555,7 +555,7 @@ partial class Dump
|
||||
}
|
||||
}
|
||||
|
||||
_opticalDiscSpiral?.PaintSectorGood(i + r);
|
||||
_mediaGraph?.PaintSectorGood(i + r);
|
||||
|
||||
imageWriteDuration += (DateTime.Now - writeStart).TotalSeconds;
|
||||
}
|
||||
@@ -589,7 +589,7 @@ partial class Dump
|
||||
|
||||
imageWriteDuration += (DateTime.Now - writeStart).TotalSeconds;
|
||||
|
||||
_opticalDiscSpiral?.PaintSectorBad(i + r);
|
||||
_mediaGraph?.PaintSectorBad(i + r);
|
||||
|
||||
_resume.BadBlocks.Add(i + r);
|
||||
|
||||
@@ -718,9 +718,7 @@ partial class Dump
|
||||
}
|
||||
}
|
||||
|
||||
if(_opticalDiscSpiral is not null)
|
||||
for(int p = 0; p < blocksToRead; p++)
|
||||
_opticalDiscSpiral?.PaintSectorGood(i + (ulong)p);
|
||||
_mediaGraph?.PaintSectorsGood(i, blocksToRead);
|
||||
|
||||
imageWriteDuration += (DateTime.Now - writeStart).TotalSeconds;
|
||||
}
|
||||
|
||||
@@ -1121,14 +1121,12 @@ sealed partial class Dump
|
||||
|
||||
if(discSpiralParameters is not null)
|
||||
{
|
||||
_opticalDiscSpiral = new Spiral((int)_dimensions, (int)_dimensions, discSpiralParameters, blocks);
|
||||
_mediaGraph = new Spiral((int)_dimensions, (int)_dimensions, discSpiralParameters, blocks);
|
||||
|
||||
foreach(Tuple<ulong, ulong> e in extents.ToArray())
|
||||
for(ulong b = e.Item1; b <= e.Item2; b++)
|
||||
_opticalDiscSpiral?.PaintSectorGood(b);
|
||||
_mediaGraph?.PaintSectorsGood(e.Item1, (uint)(e.Item2 - e.Item1 + 2));
|
||||
|
||||
foreach(ulong b in _resume.BadBlocks)
|
||||
_opticalDiscSpiral?.PaintSectorBad(b);
|
||||
_mediaGraph?.PaintSectorsBad(_resume.BadBlocks);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -339,7 +339,7 @@ partial class Dump
|
||||
{
|
||||
_resume.BadBlocks.Remove(badSector);
|
||||
extents.Add(badSector);
|
||||
_opticalDiscSpiral?.PaintSectorGood(badSector);
|
||||
_mediaGraph?.PaintSectorGood(badSector);
|
||||
|
||||
UpdateStatus?.Invoke(string.Format(Localization.Core.Correctly_retried_sector_0_in_pass_1, badSector,
|
||||
pass));
|
||||
|
||||
@@ -77,7 +77,7 @@ partial class Dump
|
||||
tmpBuf = new byte[cmdBuf.Length - 4];
|
||||
Array.Copy(cmdBuf, 4, tmpBuf, 0, cmdBuf.Length - 4);
|
||||
mediaTags.Add(MediaTagType.CD_ATIP, tmpBuf);
|
||||
_opticalDiscSpiral?.PaintRecordableInformationGood();
|
||||
_mediaGraph?.PaintRecordableInformationGood();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -111,7 +111,7 @@ partial class Dump
|
||||
tmpBuf = new byte[cmdBuf.Length - 4];
|
||||
Array.Copy(cmdBuf, 4, tmpBuf, 0, cmdBuf.Length - 4);
|
||||
mediaTags.Add(MediaTagType.CD_PMA, tmpBuf);
|
||||
_opticalDiscSpiral?.PaintRecordableInformationGood();
|
||||
_mediaGraph?.PaintRecordableInformationGood();
|
||||
}
|
||||
|
||||
_dumpLog.WriteLine(Localization.Core.Reading_Session_Information);
|
||||
|
||||
@@ -223,7 +223,7 @@ partial class Dump
|
||||
{
|
||||
_resume.BadBlocks.Remove(badSector);
|
||||
extents.Add(badSector);
|
||||
_opticalDiscSpiral?.PaintSectorGood(badSector);
|
||||
_mediaGraph?.PaintSectorGood(badSector);
|
||||
}
|
||||
|
||||
// Because one block has been partially used to fix the offset
|
||||
|
||||
@@ -41,7 +41,6 @@ using Aaru.CommonTypes;
|
||||
using Aaru.CommonTypes.Enums;
|
||||
using Aaru.CommonTypes.Interfaces;
|
||||
using Aaru.CommonTypes.Metadata;
|
||||
using Aaru.Core.Graphics;
|
||||
using Aaru.Core.Logging;
|
||||
using Aaru.Database;
|
||||
using Aaru.Devices;
|
||||
@@ -66,9 +65,11 @@ public enum DumpSubchannel
|
||||
|
||||
public partial class Dump
|
||||
{
|
||||
readonly bool _createGraph;
|
||||
readonly bool _debug;
|
||||
readonly Device _dev;
|
||||
readonly string _devicePath;
|
||||
readonly uint _dimensions;
|
||||
readonly bool _doResume;
|
||||
readonly DumpLog _dumpLog;
|
||||
readonly bool _dumpRaw;
|
||||
@@ -96,14 +97,12 @@ public partial class Dump
|
||||
readonly bool _titleKeys;
|
||||
readonly bool _trim;
|
||||
bool _aborted;
|
||||
readonly bool _createGraph;
|
||||
AaruContext _ctx; // Main database context
|
||||
Database.Models.Device _dbDev; // Device database entry
|
||||
readonly uint _dimensions;
|
||||
bool _dumpFirstTrackPregap;
|
||||
bool _fixOffset;
|
||||
uint _maximumReadable; // Maximum number of sectors drive can read at once
|
||||
Spiral _opticalDiscSpiral;
|
||||
IMediaGraph _mediaGraph;
|
||||
Resume _resume;
|
||||
Sidecar _sidecarClass;
|
||||
uint _skip;
|
||||
@@ -284,15 +283,10 @@ public partial class Dump
|
||||
_resume.LastWriteDate = DateTime.UtcNow;
|
||||
_resume.BadBlocks.Sort();
|
||||
|
||||
if(_createGraph && _opticalDiscSpiral is not null)
|
||||
if(_createGraph && _mediaGraph is not null)
|
||||
{
|
||||
foreach(ulong b in _resume.BadBlocks)
|
||||
_opticalDiscSpiral?.PaintSectorBad(b);
|
||||
|
||||
string spiralFilename = $"{_outputPrefix}.graph.png";
|
||||
var spiralFs = new FileStream(spiralFilename, FileMode.Create);
|
||||
_opticalDiscSpiral.WriteToStream(spiralFs);
|
||||
spiralFs.Close();
|
||||
_mediaGraph?.PaintSectorsBad(_resume.BadBlocks);
|
||||
_mediaGraph?.WriteTo($"{_outputPrefix}.graph.png");
|
||||
}
|
||||
|
||||
if(File.Exists(_outputPrefix + ".resume.xml"))
|
||||
|
||||
@@ -214,10 +214,7 @@ partial class Dump
|
||||
outputFormat.WriteSectors(buffer, i, blocksToRead);
|
||||
imageWriteDuration += (DateTime.Now - writeStart).TotalSeconds;
|
||||
extents.Add(i, blocksToRead, true);
|
||||
|
||||
if(_opticalDiscSpiral is not null)
|
||||
for(int b = 0; b < blocksToRead; b++)
|
||||
_opticalDiscSpiral.PaintSectorGood(i + (ulong)b);
|
||||
_mediaGraph?.PaintSectorsGood(i, blocksToRead);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
@@ -716,14 +716,12 @@ partial class Dump
|
||||
|
||||
if(discSpiralParameters is not null)
|
||||
{
|
||||
_opticalDiscSpiral = new Spiral((int)_dimensions, (int)_dimensions, discSpiralParameters, blocks);
|
||||
_mediaGraph = new Spiral((int)_dimensions, (int)_dimensions, discSpiralParameters, blocks);
|
||||
|
||||
foreach(Tuple<ulong, ulong> e in extents.ToArray())
|
||||
for(ulong b = e.Item1; b <= e.Item2; b++)
|
||||
_opticalDiscSpiral?.PaintSectorGood(b);
|
||||
_mediaGraph?.PaintSectorsGood(e.Item1, (uint)(e.Item2 - e.Item1 + 1));
|
||||
|
||||
foreach(ulong b in _resume.BadBlocks)
|
||||
_opticalDiscSpiral?.PaintSectorBad(b);
|
||||
_mediaGraph?.PaintSectorsBad(_resume.BadBlocks);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -278,7 +278,7 @@ partial class Dump
|
||||
_resume.BadBlocks.Remove(badSector);
|
||||
extents.Add(badSector);
|
||||
outputFormat.WriteSector(buffer, badSector);
|
||||
_opticalDiscSpiral?.PaintSectorGood(badSector);
|
||||
_mediaGraph?.PaintSectorGood(badSector);
|
||||
|
||||
UpdateStatus?.Invoke(string.Format(Localization.Core.Correctly_retried_block_0_in_pass_1, badSector,
|
||||
pass));
|
||||
|
||||
@@ -91,7 +91,7 @@ partial class Dump
|
||||
_resume.BadBlocks.Remove(badSector);
|
||||
extents.Add(badSector);
|
||||
outputFormat.WriteSector(buffer, badSector);
|
||||
_opticalDiscSpiral?.PaintSectorGood(badSector);
|
||||
_mediaGraph?.PaintSectorGood(badSector);
|
||||
}
|
||||
|
||||
if(newBlank)
|
||||
|
||||
Reference in New Issue
Block a user