diff --git a/Distance/Models/Stateless/FilterLogicA.cs b/Distance/Models/Stateless/FilterLogicA.cs
index 0b4e4b2..1b75a19 100644
--- a/Distance/Models/Stateless/FilterLogicA.cs
+++ b/Distance/Models/Stateless/FilterLogicA.cs
@@ -71,7 +71,7 @@ internal static class FilterLogicA
continue;
if (!string.IsNullOrEmpty(distanceSettings.FocusModel))
{
- model = Metadata.Models.Stateless.IMetadata.GetModel(locationContainer.ExifDirectory);
+ model = IMetaBase.GetModel(locationContainer.ExifDirectory);
if (string.IsNullOrEmpty(model) || !model.Contains(distanceSettings.FocusModel))
continue;
}
diff --git a/Metadata/AA.Metadata.csproj b/Metadata/AA.Metadata.csproj
index 8cbf484..83ade6b 100644
--- a/Metadata/AA.Metadata.csproj
+++ b/Metadata/AA.Metadata.csproj
@@ -11,7 +11,7 @@
Phares.AA.Metadata
- 8.0.114.$([System.Math]::Floor($([MSBuild]::Divide($([MSBuild]::Subtract($([System.DateTimeOffset]::UtcNow.ToUnixTimeSeconds()), 1699920000)), 3600))))
+ 8.0.118.$([System.Math]::Floor($([MSBuild]::Divide($([MSBuild]::Subtract($([System.DateTimeOffset]::UtcNow.ToUnixTimeSeconds()), 1699920000)), 3600))))
Phares
Mike Phares
true
diff --git a/Metadata/Models/Stateless/Base.cs b/Metadata/Models/Stateless/Base.cs
deleted file mode 100644
index ac931da..0000000
--- a/Metadata/Models/Stateless/Base.cs
+++ /dev/null
@@ -1,68 +0,0 @@
-using System.Collections.ObjectModel;
-using View_by_Distance.Shared.Models;
-
-namespace View_by_Distance.Metadata.Models.Stateless;
-
-internal static class Base
-{
-
- internal static string? GetMaker(ExifDirectoryBase[]? exifBaseDirectories)
- {
- string? result = null;
- if (exifBaseDirectories is not null)
- {
- string value;
- foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
- {
- value = exifDirectoryBase?.Make is null ? string.Empty : exifDirectoryBase.Make.ToString().Trim();
- if (string.IsNullOrEmpty(value))
- result = null;
- else
- {
- result = $"{value[0].ToString().ToUpper()}{value[1..].ToLower()}";
- break;
- }
- }
- }
- return result;
- }
-
- internal static string? GetModel(ExifDirectoryBase[]? exifBaseDirectories)
- {
- string? result = null;
- if (exifBaseDirectories is not null)
- {
- string value;
- foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
- {
- value = exifDirectoryBase?.Model is null ? string.Empty : exifDirectoryBase.Model.ToString().Trim();
- if (string.IsNullOrEmpty(value))
- result = null;
- else
- {
- result = value;
- break;
- }
- }
- }
- return result;
- }
-
- internal static ReadOnlyCollection GetKeywords(ExifDirectoryBase[]? exifBaseDirectories)
- {
- List results = [];
- if (exifBaseDirectories is not null)
- {
- string value;
- foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
- {
- value = exifDirectoryBase?.WinKeywords is null ? string.Empty : exifDirectoryBase.WinKeywords.ToString().Trim();
- if (string.IsNullOrEmpty(value))
- continue;
- results.Add(value);
- }
- }
- return results.AsReadOnly();
- }
-
-}
\ No newline at end of file
diff --git a/Metadata/Models/Stateless/Exif.cs b/Metadata/Models/Stateless/Exif.cs
index 3583933..b223851 100644
--- a/Metadata/Models/Stateless/Exif.cs
+++ b/Metadata/Models/Stateless/Exif.cs
@@ -27,24 +27,22 @@ internal abstract class Exif
private static Shared.Models.AviDirectory[] GetAviDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.AviDirectory aviDirectory;
IEnumerable aviDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.Avi.AviDirectory a in aviDirectories)
+ foreach (MetadataExtractor.Formats.Avi.AviDirectory aviDirectory in aviDirectories)
{
- if (a.Tags.Count == 0)
+ if (aviDirectory.Tags.Count == 0)
continue;
DateTime? dateTimeOriginal;
- string? duration = a.GetDescription(MetadataExtractor.Formats.Avi.AviDirectory.TagDuration);
- string? height = a.GetDescription(MetadataExtractor.Formats.Avi.AviDirectory.TagHeight);
- string? width = a.GetDescription(MetadataExtractor.Formats.Avi.AviDirectory.TagWidth);
- if (a.TryGetDateTime(MetadataExtractor.Formats.Avi.AviDirectory.TagDateTimeOriginal, out DateTime checkDateTime))
+ string? duration = aviDirectory.GetDescription(MetadataExtractor.Formats.Avi.AviDirectory.TagDuration);
+ string? height = aviDirectory.GetDescription(MetadataExtractor.Formats.Avi.AviDirectory.TagHeight);
+ string? width = aviDirectory.GetDescription(MetadataExtractor.Formats.Avi.AviDirectory.TagWidth);
+ if (aviDirectory.TryGetDateTime(MetadataExtractor.Formats.Avi.AviDirectory.TagDateTimeOriginal, out DateTime checkDateTime))
dateTimeOriginal = checkDateTime;
else
- dateTimeOriginal = GetDateTime(a.GetString(MetadataExtractor.Formats.Avi.AviDirectory.TagDateTimeOriginal));
+ dateTimeOriginal = GetDateTime(aviDirectory.GetString(MetadataExtractor.Formats.Avi.AviDirectory.TagDateTimeOriginal));
if (dateTimeOriginal is null && duration is null && height is null && width is null)
continue;
- aviDirectory = new(dateTimeOriginal, duration, height, width);
- results.Add(aviDirectory);
+ results.Add(new(dateTimeOriginal, duration, height, width));
}
return results.ToArray();
}
@@ -52,71 +50,72 @@ internal abstract class Exif
private static Shared.Models.ExifDirectoryBase[] GetExifBaseDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.ExifDirectoryBase exifDirectoryBase;
IEnumerable exifBaseDirectories = directories.OfType();
- foreach (ExifDirectoryBase e in exifBaseDirectories)
+ foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
{
- if (e.Tags.Count == 0)
+ if (exifDirectoryBase.Tags.Count == 0)
continue;
DateTime? dateTime;
DateTime checkDateTime;
DateTime? dateTimeOriginal;
DateTime? dateTimeDigitized;
- string? aperture = e.GetDescription(ExifDirectoryBase.TagAperture);
- string? applicationNotes = e.GetDescription(ExifDirectoryBase.TagApplicationNotes);
- string? artist = e.GetDescription(ExifDirectoryBase.TagArtist);
- string? bitsPerSample = e.GetDescription(ExifDirectoryBase.TagBitsPerSample);
- string? bodySerialNumber = e.GetDescription(ExifDirectoryBase.TagBodySerialNumber);
- string? cameraOwnerName = e.GetDescription(ExifDirectoryBase.TagCameraOwnerName);
- string? compressedAverageBitsPerPixel = e.GetDescription(ExifDirectoryBase.TagCompressedAverageBitsPerPixel);
- string? compression = e.GetDescription(ExifDirectoryBase.TagCompression);
- string? copyright = e.GetDescription(ExifDirectoryBase.TagCopyright);
- string? documentName = e.GetDescription(ExifDirectoryBase.TagDocumentName);
- string? exifVersion = e.GetDescription(ExifDirectoryBase.TagExifVersion);
- string? exposureTime = e.GetDescription(ExifDirectoryBase.TagExposureTime);
- string? fileSource = e.GetDescription(ExifDirectoryBase.TagFileSource);
- string? imageDescription = e.GetDescription(ExifDirectoryBase.TagImageDescription);
- string? imageHeight = e.GetDescription(ExifDirectoryBase.TagImageHeight);
- string? imageNumber = e.GetDescription(ExifDirectoryBase.TagImageNumber);
- string? imageUniqueId = e.GetDescription(ExifDirectoryBase.TagImageUniqueId);
- string? imageWidth = e.GetDescription(ExifDirectoryBase.TagImageWidth);
- string? isoSpeed = e.GetDescription(ExifDirectoryBase.TagIsoSpeed);
- string? lensMake = e.GetDescription(ExifDirectoryBase.TagLensMake);
- string? lensModel = e.GetDescription(ExifDirectoryBase.TagLensModel);
- string? lensSerialNumber = e.GetDescription(ExifDirectoryBase.TagLensSerialNumber);
- string? make = e.GetDescription(ExifDirectoryBase.TagMake);
- string? makerNote = e.GetDescription(ExifDirectoryBase.TagMakernote);
- string? model = e.GetDescription(ExifDirectoryBase.TagModel);
- string? orientation = e.GetDescription(ExifDirectoryBase.TagOrientation);
- int? orientationValue = orientation is null ? null : e.GetInt32(ExifDirectoryBase.TagOrientation);
- string? rating = e.GetDescription(ExifDirectoryBase.TagRating);
- string? ratingPercent = e.GetDescription(ExifDirectoryBase.TagRatingPercent);
- string? securityClassification = e.GetDescription(ExifDirectoryBase.TagSecurityClassification);
- string? shutterSpeed = e.GetDescription(ExifDirectoryBase.TagShutterSpeed);
- string? software = e.GetDescription(ExifDirectoryBase.TagSoftware);
- string? timeZone = e.GetDescription(ExifDirectoryBase.TagTimeZone);
- string? timeZoneDigitized = e.GetDescription(ExifDirectoryBase.TagTimeZoneDigitized);
- string? timeZoneOriginal = e.GetDescription(ExifDirectoryBase.TagTimeZoneOriginal);
- string? userComment = e.GetDescription(ExifDirectoryBase.TagUserComment);
- string? winAuthor = e.GetDescription(ExifDirectoryBase.TagWinAuthor);
- string? winComment = e.GetDescription(ExifDirectoryBase.TagWinComment);
- string? winKeywords = e.GetDescription(ExifDirectoryBase.TagWinKeywords);
- string? winSubject = e.GetDescription(ExifDirectoryBase.TagWinSubject);
- string? winTitle = e.GetDescription(ExifDirectoryBase.TagWinTitle);
- string? xResolution = e.GetDescription(ExifDirectoryBase.TagXResolution);
- string? yResolution = e.GetDescription(ExifDirectoryBase.TagYResolution);
- if (e.TryGetDateTime(ExifDirectoryBase.TagDateTime, out checkDateTime))
+ string? aperture = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagAperture);
+ string? applicationNotes = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagApplicationNotes);
+ string? artist = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagArtist);
+ string? bitsPerSample = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagBitsPerSample);
+ string? bodySerialNumber = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagBodySerialNumber);
+ string? cameraOwnerName = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagCameraOwnerName);
+ string? compressedAverageBitsPerPixel = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagCompressedAverageBitsPerPixel);
+ string? compression = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagCompression);
+ string? copyright = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagCopyright);
+ string? documentName = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagDocumentName);
+ string? exifVersion = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagExifVersion);
+ string? exposureTime = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagExposureTime);
+ string? fileSource = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagFileSource);
+ string? imageDescription = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagImageDescription);
+ string? imageHeight = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagImageHeight);
+ int? imageHeightValue = imageHeight is null ? null : exifDirectoryBase.GetInt32(ExifDirectoryBase.TagImageHeight);
+ string? imageNumber = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagImageNumber);
+ string? imageUniqueId = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagImageUniqueId);
+ string? imageWidth = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagImageWidth);
+ int? imageWidthValue = imageWidth is null ? null : exifDirectoryBase.GetInt32(ExifDirectoryBase.TagImageWidth);
+ string? isoSpeed = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagIsoSpeed);
+ string? lensMake = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagLensMake);
+ string? lensModel = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagLensModel);
+ string? lensSerialNumber = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagLensSerialNumber);
+ string? make = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagMake);
+ string? makerNote = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagMakernote);
+ string? model = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagModel);
+ string? orientation = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagOrientation);
+ int? orientationValue = orientation is null ? null : exifDirectoryBase.GetInt32(ExifDirectoryBase.TagOrientation);
+ string? rating = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagRating);
+ string? ratingPercent = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagRatingPercent);
+ string? securityClassification = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagSecurityClassification);
+ string? shutterSpeed = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagShutterSpeed);
+ string? software = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagSoftware);
+ string? timeZone = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagTimeZone);
+ string? timeZoneDigitized = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagTimeZoneDigitized);
+ string? timeZoneOriginal = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagTimeZoneOriginal);
+ string? userComment = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagUserComment);
+ string? winAuthor = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagWinAuthor);
+ string? winComment = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagWinComment);
+ string? winKeywords = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagWinKeywords);
+ string? winSubject = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagWinSubject);
+ string? winTitle = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagWinTitle);
+ string? xResolution = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagXResolution);
+ string? yResolution = exifDirectoryBase.GetDescription(ExifDirectoryBase.TagYResolution);
+ if (exifDirectoryBase.TryGetDateTime(ExifDirectoryBase.TagDateTime, out checkDateTime))
dateTime = checkDateTime;
else
- dateTime = GetDateTime(e.GetString(ExifDirectoryBase.TagDateTime));
- if (e.TryGetDateTime(ExifDirectoryBase.TagDateTimeOriginal, out checkDateTime))
+ dateTime = GetDateTime(exifDirectoryBase.GetString(ExifDirectoryBase.TagDateTime));
+ if (exifDirectoryBase.TryGetDateTime(ExifDirectoryBase.TagDateTimeOriginal, out checkDateTime))
dateTimeOriginal = checkDateTime;
else
- dateTimeOriginal = GetDateTime(e.GetString(ExifDirectoryBase.TagDateTimeOriginal));
- if (e.TryGetDateTime(ExifDirectoryBase.TagDateTimeDigitized, out checkDateTime))
+ dateTimeOriginal = GetDateTime(exifDirectoryBase.GetString(ExifDirectoryBase.TagDateTimeOriginal));
+ if (exifDirectoryBase.TryGetDateTime(ExifDirectoryBase.TagDateTimeDigitized, out checkDateTime))
dateTimeDigitized = checkDateTime;
else
- dateTimeDigitized = GetDateTime(e.GetString(ExifDirectoryBase.TagDateTimeDigitized));
+ dateTimeDigitized = GetDateTime(exifDirectoryBase.GetString(ExifDirectoryBase.TagDateTimeDigitized));
if (userComment is not null && userComment.Length > 255)
userComment = "...";
if (aperture is null
@@ -166,53 +165,54 @@ internal abstract class Exif
&& xResolution is not null
&& yResolution is null)
continue;
- exifDirectoryBase = new(aperture,
- applicationNotes,
- artist,
- bitsPerSample,
- bodySerialNumber,
- cameraOwnerName,
- compressedAverageBitsPerPixel,
- compression,
- copyright,
- dateTime,
- dateTimeDigitized,
- dateTimeOriginal,
- documentName,
- exifVersion,
- exposureTime,
- fileSource,
- imageDescription,
- imageHeight,
- imageNumber,
- imageUniqueId,
- imageWidth,
- isoSpeed,
- lensMake,
- lensModel,
- lensSerialNumber,
- make,
- makerNote,
- model,
- orientation,
- orientationValue,
- rating,
- ratingPercent,
- securityClassification,
- shutterSpeed,
- software,
- timeZone,
- timeZoneDigitized,
- timeZoneOriginal,
- userComment,
- winAuthor,
- winComment,
- winKeywords,
- winSubject,
- winTitle,
- xResolution,
- yResolution);
- results.Add(exifDirectoryBase);
+ results.Add(new(Aperture: aperture,
+ ApplicationNotes: applicationNotes,
+ Artist: artist,
+ BitsPerSample: bitsPerSample,
+ BodySerialNumber: bodySerialNumber,
+ CameraOwnerName: cameraOwnerName,
+ CompressedAverageBitsPerPixel: compressedAverageBitsPerPixel,
+ Compression: compression,
+ Copyright: copyright,
+ DateTime: dateTime,
+ DateTimeDigitized: dateTimeDigitized,
+ DateTimeOriginal: dateTimeOriginal,
+ DocumentName: documentName,
+ ExifVersion: exifVersion,
+ ExposureTime: exposureTime,
+ FileSource: fileSource,
+ ImageDescription: imageDescription,
+ ImageHeight: imageHeight,
+ ImageHeightValue: imageHeightValue,
+ ImageNumber: imageNumber,
+ ImageUniqueId: imageUniqueId,
+ ImageWidth: imageWidth,
+ ImageWidthValue: imageWidthValue,
+ IsoSpeed: isoSpeed,
+ LensMake: lensMake,
+ LensModel: lensModel,
+ LensSerialNumber: lensSerialNumber,
+ Make: make,
+ MakerNote: makerNote,
+ Model: model,
+ Orientation: orientation,
+ OrientationValue: orientationValue,
+ Rating: rating,
+ RatingPercent: ratingPercent,
+ SecurityClassification: securityClassification,
+ ShutterSpeed: shutterSpeed,
+ Software: software,
+ TimeZone: timeZone,
+ TimeZoneDigitized: timeZoneDigitized,
+ TimeZoneOriginal: timeZoneOriginal,
+ UserComment: userComment,
+ WinAuthor: winAuthor,
+ WinComment: winComment,
+ WinKeywords: winKeywords,
+ WinSubject: winSubject,
+ WinTitle: winTitle,
+ XResolution: xResolution,
+ YResolution: yResolution));
}
return results.ToArray();
}
@@ -220,25 +220,23 @@ internal abstract class Exif
private static Shared.Models.FileMetadataDirectory[] GetFileMetadataDirectories(string file, IReadOnlyList directories)
{
List results = [];
- Shared.Models.FileMetadataDirectory fileMetadataDirectory;
IEnumerable fileMetadataDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.FileSystem.FileMetadataDirectory f in fileMetadataDirectories)
+ foreach (MetadataExtractor.Formats.FileSystem.FileMetadataDirectory fileMetadataDirectory in fileMetadataDirectories)
{
- if (f.Tags.Count == 0)
+ if (fileMetadataDirectory.Tags.Count == 0)
continue;
DateTime? fileModifiedDate;
- string? fileName = f.GetDescription(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileName);
- string? fileSize = f.GetDescription(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileSize);
- if (f.TryGetDateTime(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileModifiedDate, out DateTime checkDateTime))
+ string? fileName = fileMetadataDirectory.GetDescription(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileName);
+ string? fileSize = fileMetadataDirectory.GetDescription(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileSize);
+ if (fileMetadataDirectory.TryGetDateTime(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileModifiedDate, out DateTime checkDateTime))
fileModifiedDate = checkDateTime;
else
- fileModifiedDate = GetDateTime(f.GetString(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileModifiedDate));
+ fileModifiedDate = GetDateTime(fileMetadataDirectory.GetString(MetadataExtractor.Formats.FileSystem.FileMetadataDirectory.TagFileModifiedDate));
if (fileName is null || !file.EndsWith(fileName))
throw new NotSupportedException($"!{file}.EndsWith({fileName})");
if (fileModifiedDate is null && fileName is null && fileSize is null)
continue;
- fileMetadataDirectory = new(fileModifiedDate, fileName, fileSize);
- results.Add(fileMetadataDirectory);
+ results.Add(new(fileModifiedDate, fileName, fileSize));
}
return results.ToArray();
}
@@ -246,18 +244,16 @@ internal abstract class Exif
private static Shared.Models.GifHeaderDirectory[] GetGifHeaderDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.GifHeaderDirectory gifHeaderDirectory;
IEnumerable gifHeaderDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.Gif.GifHeaderDirectory g in gifHeaderDirectories)
+ foreach (MetadataExtractor.Formats.Gif.GifHeaderDirectory gifHeaderDirectory in gifHeaderDirectories)
{
- if (g.Tags.Count == 0)
+ if (gifHeaderDirectory.Tags.Count == 0)
continue;
- string? imageHeight = g.GetDescription(MetadataExtractor.Formats.Gif.GifHeaderDirectory.TagImageHeight);
- string? imageWidth = g.GetDescription(MetadataExtractor.Formats.Gif.GifHeaderDirectory.TagImageWidth);
+ string? imageHeight = gifHeaderDirectory.GetDescription(MetadataExtractor.Formats.Gif.GifHeaderDirectory.TagImageHeight);
+ string? imageWidth = gifHeaderDirectory.GetDescription(MetadataExtractor.Formats.Gif.GifHeaderDirectory.TagImageWidth);
if (imageHeight is null && imageWidth is null)
continue;
- gifHeaderDirectory = new(imageHeight, imageWidth);
- results.Add(gifHeaderDirectory);
+ results.Add(new(imageHeight, imageWidth));
}
return results.ToArray();
}
@@ -265,31 +261,29 @@ internal abstract class Exif
private static Shared.Models.GpsDirectory[] GetGpsDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.GpsDirectory gpsDirectory;
IEnumerable gpsDirectories = directories.OfType();
- foreach (GpsDirectory g in gpsDirectories)
+ foreach (GpsDirectory gpsDirectory in gpsDirectories)
{
- if (g.Tags.Count == 0)
+ if (gpsDirectory.Tags.Count == 0)
continue;
DateTime? timeStamp;
- string? altitude = g.GetDescription(GpsDirectory.TagAltitude);
- string? latitude = g.GetDescription(GpsDirectory.TagLatitude);
- string? latitudeRef = g.GetDescription(GpsDirectory.TagLatitudeRef);
- string? longitude = g.GetDescription(GpsDirectory.TagLongitude);
- string? longitudeRef = g.GetDescription(GpsDirectory.TagLongitudeRef);
- if (g.TryGetDateTime(GpsDirectory.TagTimeStamp, out DateTime checkDateTime))
+ string? altitude = gpsDirectory.GetDescription(GpsDirectory.TagAltitude);
+ string? latitude = gpsDirectory.GetDescription(GpsDirectory.TagLatitude);
+ string? latitudeRef = gpsDirectory.GetDescription(GpsDirectory.TagLatitudeRef);
+ string? longitude = gpsDirectory.GetDescription(GpsDirectory.TagLongitude);
+ string? longitudeRef = gpsDirectory.GetDescription(GpsDirectory.TagLongitudeRef);
+ if (gpsDirectory.TryGetDateTime(GpsDirectory.TagTimeStamp, out DateTime checkDateTime))
timeStamp = checkDateTime;
else
- timeStamp = GetDateTime(g.GetString(GpsDirectory.TagTimeStamp));
+ timeStamp = GetDateTime(gpsDirectory.GetString(GpsDirectory.TagTimeStamp));
if (altitude is null && latitude is null && latitudeRef is null && longitude is null && longitudeRef is null && timeStamp is null)
continue;
- gpsDirectory = new(altitude,
- latitude,
- latitudeRef,
- longitude,
- longitudeRef,
- timeStamp);
- results.Add(gpsDirectory);
+ results.Add(new(altitude,
+ latitude,
+ latitudeRef,
+ longitude,
+ longitudeRef,
+ timeStamp));
}
return results.ToArray();
}
@@ -297,18 +291,16 @@ internal abstract class Exif
private static Shared.Models.JpegDirectory[] GetJpegDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.JpegDirectory jpegDirectory;
IEnumerable jpegDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.Jpeg.JpegDirectory j in jpegDirectories)
+ foreach (MetadataExtractor.Formats.Jpeg.JpegDirectory jpegDirectory in jpegDirectories)
{
- if (j.Tags.Count == 0)
+ if (jpegDirectory.Tags.Count == 0)
continue;
- string? imageHeight = j.GetDescription(MetadataExtractor.Formats.Jpeg.JpegDirectory.TagImageHeight);
- string? imageWidth = j.GetDescription(MetadataExtractor.Formats.Jpeg.JpegDirectory.TagImageWidth);
+ string? imageHeight = jpegDirectory.GetDescription(MetadataExtractor.Formats.Jpeg.JpegDirectory.TagImageHeight);
+ string? imageWidth = jpegDirectory.GetDescription(MetadataExtractor.Formats.Jpeg.JpegDirectory.TagImageWidth);
if (imageHeight is null && imageWidth is null)
continue;
- jpegDirectory = new(imageHeight, imageWidth);
- results.Add(jpegDirectory);
+ results.Add(new(imageHeight, imageWidth));
}
return results.ToArray();
}
@@ -316,7 +308,6 @@ internal abstract class Exif
private static Shared.Models.MakernoteDirectory[] GetMakernoteDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.MakernoteDirectory makernoteDirectory;
IEnumerable appleMakernoteDirectories = directories.OfType();
foreach (AppleMakernoteDirectory appleMakernoteDirectory in appleMakernoteDirectories)
{
@@ -327,8 +318,7 @@ internal abstract class Exif
string? qualityAndFileFormat = null;
if (cameraSerialNumber is null && firmwareVersion is null && qualityAndFileFormat is null)
continue;
- makernoteDirectory = new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat);
- results.Add(makernoteDirectory);
+ results.Add(new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat));
}
IEnumerable canonMakernoteDirectories = directories.OfType();
foreach (CanonMakernoteDirectory canonMakernoteDirectory in canonMakernoteDirectories)
@@ -340,8 +330,7 @@ internal abstract class Exif
string? qualityAndFileFormat = canonMakernoteDirectory.GetDescription(CanonMakernoteDirectory.CameraSettings.TagQuality);
if (cameraSerialNumber is null && firmwareVersion is null && qualityAndFileFormat is null)
continue;
- makernoteDirectory = new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat);
- results.Add(makernoteDirectory);
+ results.Add(new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat));
}
IEnumerable nikonType2MakernoteDirectories = directories.OfType();
foreach (NikonType2MakernoteDirectory nikonType2MakernoteDirectory in nikonType2MakernoteDirectories)
@@ -353,8 +342,7 @@ internal abstract class Exif
string? qualityAndFileFormat = nikonType2MakernoteDirectory.GetDescription(NikonType2MakernoteDirectory.TagQualityAndFileFormat);
if (cameraSerialNumber is null && firmwareVersion is null && qualityAndFileFormat is null)
continue;
- makernoteDirectory = new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat);
- results.Add(makernoteDirectory);
+ results.Add(new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat));
}
IEnumerable olympusMakernoteDirectories = directories.OfType();
foreach (OlympusMakernoteDirectory olympusMakernoteDirectory in olympusMakernoteDirectories)
@@ -366,8 +354,7 @@ internal abstract class Exif
string? qualityAndFileFormat = olympusMakernoteDirectory.GetDescription(OlympusMakernoteDirectory.TagJpegQuality);
if (cameraSerialNumber is null && firmwareVersion is null && qualityAndFileFormat is null)
continue;
- makernoteDirectory = new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat);
- results.Add(makernoteDirectory);
+ results.Add(new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat));
}
IEnumerable panasonicMakernoteDirectories = directories.OfType();
foreach (PanasonicMakernoteDirectory panasonicMakernoteDirectory in panasonicMakernoteDirectories)
@@ -379,8 +366,7 @@ internal abstract class Exif
string? qualityAndFileFormat = panasonicMakernoteDirectory.GetDescription(PanasonicMakernoteDirectory.TagQualityMode);
if (cameraSerialNumber is null && firmwareVersion is null && qualityAndFileFormat is null)
continue;
- makernoteDirectory = new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat);
- results.Add(makernoteDirectory);
+ results.Add(new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat));
}
IEnumerable samsungType2MakernoteDirectories = directories.OfType();
foreach (SamsungType2MakernoteDirectory samsungType2MakernoteDirectory in samsungType2MakernoteDirectories)
@@ -392,8 +378,7 @@ internal abstract class Exif
string? qualityAndFileFormat = null;
if (cameraSerialNumber is null && firmwareVersion is null && qualityAndFileFormat is null)
continue;
- makernoteDirectory = new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat);
- results.Add(makernoteDirectory);
+ results.Add(new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat));
}
IEnumerable sonyType6MakernoteDirectories = directories.OfType();
foreach (SonyType6MakernoteDirectory sonyType6MakernoteDirectory in sonyType6MakernoteDirectories)
@@ -405,8 +390,7 @@ internal abstract class Exif
string? qualityAndFileFormat = null;
if (cameraSerialNumber is null && firmwareVersion is null && qualityAndFileFormat is null)
continue;
- makernoteDirectory = new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat);
- results.Add(makernoteDirectory);
+ results.Add(new(cameraSerialNumber, firmwareVersion, qualityAndFileFormat));
}
return results.ToArray();
}
@@ -414,18 +398,16 @@ internal abstract class Exif
private static Shared.Models.PhotoshopDirectory[] GetPhotoshopDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.PhotoshopDirectory photoshopDirectory;
IEnumerable photoshopDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.Photoshop.PhotoshopDirectory p in photoshopDirectories)
+ foreach (MetadataExtractor.Formats.Photoshop.PhotoshopDirectory photoshopDirectory in photoshopDirectories)
{
- if (p.Tags.Count == 0)
+ if (photoshopDirectory.Tags.Count == 0)
continue;
- string? jpegQuality = p.GetDescription(MetadataExtractor.Formats.Photoshop.PhotoshopDirectory.TagJpegQuality);
- string? url = p.GetDescription(MetadataExtractor.Formats.Photoshop.PhotoshopDirectory.TagUrl);
+ string? jpegQuality = photoshopDirectory.GetDescription(MetadataExtractor.Formats.Photoshop.PhotoshopDirectory.TagJpegQuality);
+ string? url = photoshopDirectory.GetDescription(MetadataExtractor.Formats.Photoshop.PhotoshopDirectory.TagUrl);
if (jpegQuality is null && url is null)
continue;
- photoshopDirectory = new(jpegQuality, url);
- results.Add(photoshopDirectory);
+ results.Add(new(jpegQuality, url));
}
return results.ToArray();
}
@@ -433,19 +415,17 @@ internal abstract class Exif
private static Shared.Models.PngDirectory[] GetPngDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.PngDirectory pngDirectory;
IEnumerable pngDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.Png.PngDirectory p in pngDirectories)
+ foreach (MetadataExtractor.Formats.Png.PngDirectory pngDirectory in pngDirectories)
{
- if (p.Tags.Count == 0)
+ if (pngDirectory.Tags.Count == 0)
continue;
- string? imageHeight = p.GetDescription(MetadataExtractor.Formats.Png.PngDirectory.TagImageHeight);
- string? imageWidth = p.GetDescription(MetadataExtractor.Formats.Png.PngDirectory.TagImageWidth);
- string? textualData = p.GetDescription(MetadataExtractor.Formats.Png.PngDirectory.TagTextualData);
+ string? imageHeight = pngDirectory.GetDescription(MetadataExtractor.Formats.Png.PngDirectory.TagImageHeight);
+ string? imageWidth = pngDirectory.GetDescription(MetadataExtractor.Formats.Png.PngDirectory.TagImageWidth);
+ string? textualData = pngDirectory.GetDescription(MetadataExtractor.Formats.Png.PngDirectory.TagTextualData);
if (imageHeight is null && imageWidth is null && textualData is null)
continue;
- pngDirectory = new(imageHeight, imageWidth, textualData);
- results.Add(pngDirectory);
+ results.Add(new(imageHeight, imageWidth, textualData));
}
return results.ToArray();
}
@@ -453,21 +433,19 @@ internal abstract class Exif
private static Shared.Models.QuickTimeMovieHeaderDirectory[] GetQuickTimeMovieHeaderDirectoryDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.QuickTimeMovieHeaderDirectory quickTimeMovieHeaderDirectory;
IEnumerable quickTimeMovieHeaderDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.QuickTime.QuickTimeMovieHeaderDirectory q in quickTimeMovieHeaderDirectories)
+ foreach (MetadataExtractor.Formats.QuickTime.QuickTimeMovieHeaderDirectory quickTimeMovieHeaderDirectory in quickTimeMovieHeaderDirectories)
{
- if (q.Tags.Count == 0)
+ if (quickTimeMovieHeaderDirectory.Tags.Count == 0)
continue;
DateTime? created;
- if (q.TryGetDateTime(MetadataExtractor.Formats.QuickTime.QuickTimeMovieHeaderDirectory.TagCreated, out DateTime checkDateTime))
+ if (quickTimeMovieHeaderDirectory.TryGetDateTime(MetadataExtractor.Formats.QuickTime.QuickTimeMovieHeaderDirectory.TagCreated, out DateTime checkDateTime))
created = checkDateTime;
else
- created = GetDateTime(q.GetString(MetadataExtractor.Formats.QuickTime.QuickTimeMovieHeaderDirectory.TagCreated));
+ created = GetDateTime(quickTimeMovieHeaderDirectory.GetString(MetadataExtractor.Formats.QuickTime.QuickTimeMovieHeaderDirectory.TagCreated));
if (created is null)
continue;
- quickTimeMovieHeaderDirectory = new(created);
- results.Add(quickTimeMovieHeaderDirectory);
+ results.Add(new(created));
}
return results.ToArray();
}
@@ -475,21 +453,19 @@ internal abstract class Exif
private static Shared.Models.QuickTimeTrackHeaderDirectory[] GetQuickTimeTrackHeaderDirectoryDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.QuickTimeTrackHeaderDirectory quickTimeTrackHeaderDirectory;
IEnumerable quickTimeTrackHeaderDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.QuickTime.QuickTimeTrackHeaderDirectory q in quickTimeTrackHeaderDirectories)
+ foreach (MetadataExtractor.Formats.QuickTime.QuickTimeTrackHeaderDirectory quickTimeTrackHeaderDirectory in quickTimeTrackHeaderDirectories)
{
- if (q.Tags.Count == 0)
+ if (quickTimeTrackHeaderDirectory.Tags.Count == 0)
continue;
DateTime? created;
- if (q.TryGetDateTime(MetadataExtractor.Formats.QuickTime.QuickTimeTrackHeaderDirectory.TagCreated, out DateTime checkDateTime))
+ if (quickTimeTrackHeaderDirectory.TryGetDateTime(MetadataExtractor.Formats.QuickTime.QuickTimeTrackHeaderDirectory.TagCreated, out DateTime checkDateTime))
created = checkDateTime;
else
- created = GetDateTime(q.GetString(MetadataExtractor.Formats.QuickTime.QuickTimeTrackHeaderDirectory.TagCreated));
+ created = GetDateTime(quickTimeTrackHeaderDirectory.GetString(MetadataExtractor.Formats.QuickTime.QuickTimeTrackHeaderDirectory.TagCreated));
if (created is null)
continue;
- quickTimeTrackHeaderDirectory = new(created);
- results.Add(quickTimeTrackHeaderDirectory);
+ results.Add(new(created));
}
return results.ToArray();
}
@@ -497,18 +473,16 @@ internal abstract class Exif
private static Shared.Models.WebPDirectory[] GetWebPDirectories(IReadOnlyList directories)
{
List results = [];
- Shared.Models.WebPDirectory webPDirectory;
IEnumerable webPDirectories = directories.OfType();
- foreach (MetadataExtractor.Formats.WebP.WebPDirectory w in webPDirectories)
+ foreach (MetadataExtractor.Formats.WebP.WebPDirectory webPDirectory in webPDirectories)
{
- if (w.Tags.Count == 0)
+ if (webPDirectory.Tags.Count == 0)
continue;
- string? imageHeight = w.GetDescription(MetadataExtractor.Formats.WebP.WebPDirectory.TagImageHeight);
- string? imageWidth = w.GetDescription(MetadataExtractor.Formats.WebP.WebPDirectory.TagImageWidth);
+ string? imageHeight = webPDirectory.GetDescription(MetadataExtractor.Formats.WebP.WebPDirectory.TagImageHeight);
+ string? imageWidth = webPDirectory.GetDescription(MetadataExtractor.Formats.WebP.WebPDirectory.TagImageWidth);
if (imageHeight is null && imageWidth is null)
continue;
- webPDirectory = new(imageHeight, imageWidth);
- results.Add(webPDirectory);
+ results.Add(new(imageHeight, imageWidth));
}
return results.ToArray();
}
@@ -523,27 +497,27 @@ internal abstract class Exif
Shared.Models.WebPDirectory[] webPDirectories = GetWebPDirectories(directories);
Shared.Models.ExifDirectoryBase[] exifBaseDirectories = GetExifBaseDirectories(directories);
Shared.Models.GifHeaderDirectory[] gifHeaderDirectories = GetGifHeaderDirectories(directories);
- Shared.Models.MakernoteDirectory[] MakernoteDirectories = GetMakernoteDirectories(directories);
+ Shared.Models.MakernoteDirectory[] makernoteDirectories = GetMakernoteDirectories(directories);
Shared.Models.PhotoshopDirectory[] photoshopDirectories = GetPhotoshopDirectories(directories);
Shared.Models.FileMetadataDirectory[] fileMetadataDirectories = GetFileMetadataDirectories(filePath.FullName, directories);
Shared.Models.QuickTimeMovieHeaderDirectory[] quickTimeMovieHeaderDirectories = GetQuickTimeMovieHeaderDirectoryDirectories(directories);
Shared.Models.QuickTimeTrackHeaderDirectory[] quickTimeTrackHeaderDirectories = GetQuickTimeTrackHeaderDirectoryDirectories(directories);
- result = new(aviDirectories,
- exifBaseDirectories,
- fileMetadataDirectories,
- filePath,
- gifHeaderDirectories,
- gpsDirectories,
- size?.Height,
- jpegDirectories,
- MakernoteDirectories,
- personKeyFormattedAndKeyTicksAndDisplayDirectoryName,
- photoshopDirectories,
- pngDirectories,
- quickTimeMovieHeaderDirectories,
- quickTimeTrackHeaderDirectories,
- webPDirectories,
- size?.Width);
+ result = new(AviDirectories: aviDirectories,
+ ExifBaseDirectories: exifBaseDirectories,
+ FileMetadataDirectories: fileMetadataDirectories,
+ FilePath: filePath,
+ GifHeaderDirectories: gifHeaderDirectories,
+ GpsDirectories: gpsDirectories,
+ Height: size?.Height ?? Shared.Models.Stateless.IMetaBase.GetHeight(exifBaseDirectories),
+ JpegDirectories: jpegDirectories,
+ MakernoteDirectories: makernoteDirectories,
+ PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName: personKeyFormattedAndKeyTicksAndDisplayDirectoryName,
+ PhotoshopDirectories: photoshopDirectories,
+ PngDirectories: pngDirectories,
+ QuickTimeMovieHeaderDirectories: quickTimeMovieHeaderDirectories,
+ QuickTimeTrackHeaderDirectories: quickTimeTrackHeaderDirectories,
+ WebPDirectories: webPDirectories,
+ Width: size?.Width ?? Shared.Models.Stateless.IMetaBase.GetWidth(exifBaseDirectories));
return result;
}
@@ -552,15 +526,10 @@ internal abstract class Exif
Shared.Models.ExifDirectory result;
IReadOnlyList directories = ImageMetadataReader.ReadMetadata(stream);
System.Drawing.Size? size;
- if (!stream.CanSeek)
- size = null;
- else
- {
- try
- { size = Dimensions.GetDimensions(stream); }
- catch (Exception)
- { size = null; }
- }
+ try
+ { size = Dimensions.GetDimensions(stream); }
+ catch (Exception)
+ { size = null; }
result = Covert(filePath, personKeyFormattedAndKeyTicksAndDisplayDirectoryName, directories, size);
return result;
}
diff --git a/Metadata/Models/Stateless/IMetadata.cs b/Metadata/Models/Stateless/IMetadata.cs
index c673cb5..81e2563 100644
--- a/Metadata/Models/Stateless/IMetadata.cs
+++ b/Metadata/Models/Stateless/IMetadata.cs
@@ -22,21 +22,6 @@ public interface IMetadata
static ExifDirectory GetExifDirectory(FilePath filePath, Stream stream, PersonKeyFormattedAndKeyTicksAndDisplayDirectoryName? personKeyFormattedAndKeyTicksAndDisplayDirectoryName) =>
Exif.GetExifDirectory(filePath, stream, personKeyFormattedAndKeyTicksAndDisplayDirectoryName);
- string? TestStatic_GetMaker(ExifDirectory? exifDirectory) =>
- GetMaker(exifDirectory);
- static string? GetMaker(ExifDirectory? exifDirectory) =>
- Base.GetMaker(exifDirectory?.ExifBaseDirectories);
-
- string? TestStatic_GetModel(ExifDirectory? exifDirectory) =>
- GetModel(exifDirectory);
- static string? GetModel(ExifDirectory? exifDirectory) =>
- Base.GetModel(exifDirectory?.ExifBaseDirectories);
-
- ReadOnlyCollection TestStatic_GetKeywords(ExifDirectory? exifDirectory) =>
- GetKeywords(exifDirectory);
- static ReadOnlyCollection GetKeywords(ExifDirectory? exifDirectory) =>
- Base.GetKeywords(exifDirectory?.ExifBaseDirectories);
-
string? TestStatic_GetOutputResolution(ExifDirectory? exifDirectory) =>
GetOutputResolution(exifDirectory);
static string? GetOutputResolution(ExifDirectory? exifDirectory) =>
diff --git a/Rename/Rename.cs b/Rename/Rename.cs
index b591aa1..7be7dc1 100644
--- a/Rename/Rename.cs
+++ b/Rename/Rename.cs
@@ -394,7 +394,7 @@ public partial class Rename : IRename, IDisposable
const string jpeg = ".jpeg";
List toDoCollection = [];
DateTime? dateTime = IDate.GetDateTimeOriginal(exifDirectory);
- ReadOnlyCollection keywords = IMetadata.GetKeywords(exifDirectory);
+ ReadOnlyCollection keywords = IMetaBase.GetKeywords(exifDirectory);
bool hasIgnoreKeyword = appSettings.MetadataSettings.IgnoreRulesKeyWords.Any(keywords.Contains);
string checkFileExtension = exifDirectory.FilePath.ExtensionLowered == jpeg ? jpg : exifDirectory.FilePath.ExtensionLowered;
bool hasDateTimeOriginal = dateTime is not null;
@@ -454,7 +454,7 @@ public partial class Rename : IRename, IDisposable
dateTime = IDate.GetDateTimeOriginal(firstPass.ExifDirectory);
hasDateTimeOriginal = dateTime is not null;
dateTime ??= IDate.GetMinimum(firstPass.ExifDirectory);
- keywords = IMetadata.GetKeywords(firstPass.ExifDirectory);
+ keywords = IMetaBase.GetKeywords(firstPass.ExifDirectory);
hasIgnoreKeyword = appSettings.MetadataSettings.IgnoreRulesKeyWords.Any(l => keywords.Contains(l));
record = new(DateTime: dateTime.Value,
ExifDirectory: firstPass.ExifDirectory,
@@ -544,7 +544,7 @@ public partial class Rename : IRename, IDisposable
hasDateTimeOriginal = dateTime is not null;
if (dateTime is null && appSettings.ResultSettings.ValidVideoFormatExtensions.Contains(record.ExifDirectory.FilePath.ExtensionLowered))
continue;
- keywords = IMetadata.GetKeywords(record.ExifDirectory);
+ keywords = IMetaBase.GetKeywords(record.ExifDirectory);
hasIgnoreKeyword = appSettings.MetadataSettings.IgnoreRulesKeyWords.Any(keywords.Contains);
}
cei = IPath.GetCombinedEnumAndIndex(appSettings.ResultSettings, record.ExifDirectory.FilePath);
@@ -640,7 +640,7 @@ public partial class Rename : IRename, IDisposable
isWrongYear = null;
string directoryName;
string tfw = GetTFW(record, isWrongYear);
- string? maker = IMetadata.GetMaker(record.ExifDirectory);
+ string? maker = IMetaBase.GetMaker(record.ExifDirectory);
string rootDirectory = appSettings.ResultSettings.RootDirectory;
string[] segments = checkDirectoryName.Split(years, StringSplitOptions.None);
(int seasonValue, string seasonName) = IDate.GetSeason(record.DateTime.DayOfYear);
diff --git a/Shared/AA.Shared.csproj b/Shared/AA.Shared.csproj
index db2257e..523541b 100644
--- a/Shared/AA.Shared.csproj
+++ b/Shared/AA.Shared.csproj
@@ -10,7 +10,7 @@
Phares.AA.Shared
- 8.0.114.$([System.Math]::Floor($([MSBuild]::Divide($([MSBuild]::Subtract($([System.DateTimeOffset]::UtcNow.ToUnixTimeSeconds()), 1699920000)), 3600))))
+ 8.0.118.$([System.Math]::Floor($([MSBuild]::Divide($([MSBuild]::Subtract($([System.DateTimeOffset]::UtcNow.ToUnixTimeSeconds()), 1699920000)), 3600))))
Phares
Mike Phares
true
diff --git a/Shared/Models/ExifDirectoryBase.cs b/Shared/Models/ExifDirectoryBase.cs
index 8235471..186d936 100644
--- a/Shared/Models/ExifDirectoryBase.cs
+++ b/Shared/Models/ExifDirectoryBase.cs
@@ -21,9 +21,11 @@ public record ExifDirectoryBase(string? Aperture,
string? FileSource,
string? ImageDescription,
string? ImageHeight,
+ int? ImageHeightValue,
string? ImageNumber,
string? ImageUniqueId,
string? ImageWidth,
+ int? ImageWidthValue,
string? IsoSpeed,
string? LensMake,
string? LensModel,
diff --git a/Shared/Models/MetaBase.cs b/Shared/Models/MetaBase.cs
new file mode 100644
index 0000000..aa71b87
--- /dev/null
+++ b/Shared/Models/MetaBase.cs
@@ -0,0 +1,135 @@
+using System.Collections.ObjectModel;
+using System.Globalization;
+
+namespace View_by_Distance.Shared.Models;
+
+internal static class MetaBase
+{
+
+ internal static string? GetMaker(ExifDirectoryBase[]? exifBaseDirectories)
+ {
+ string? result = null;
+ if (exifBaseDirectories is not null)
+ {
+ string value;
+ foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
+ {
+ value = exifDirectoryBase?.Make is null ? string.Empty : exifDirectoryBase.Make.ToString().Trim();
+ if (string.IsNullOrEmpty(value))
+ result = null;
+ else
+ {
+ result = $"{value[0].ToString().ToUpper()}{value[1..].ToLower()}";
+ break;
+ }
+ }
+ }
+ return result;
+ }
+
+ internal static string? GetModel(ExifDirectoryBase[]? exifBaseDirectories)
+ {
+ string? result = null;
+ if (exifBaseDirectories is not null)
+ {
+ string value;
+ foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
+ {
+ value = exifDirectoryBase?.Model is null ? string.Empty : exifDirectoryBase.Model.ToString().Trim();
+ if (string.IsNullOrEmpty(value))
+ result = null;
+ else
+ {
+ result = value;
+ break;
+ }
+ }
+ }
+ return result;
+ }
+
+ internal static int? GetOrientation(ExifDirectoryBase[]? exifBaseDirectories)
+ {
+ int? result = null;
+ // public const int TagOrientation = 274;
+ if (exifBaseDirectories is not null)
+ {
+ foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
+ {
+ result = exifDirectoryBase?.OrientationValue;
+ if (result is not null)
+ break;
+ }
+ }
+ return result;
+ }
+
+ internal static ReadOnlyCollection GetKeywords(ExifDirectoryBase[]? exifBaseDirectories)
+ {
+ List results = [];
+ if (exifBaseDirectories is not null)
+ {
+ string value;
+ foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
+ {
+ value = exifDirectoryBase?.WinKeywords is null ? string.Empty : exifDirectoryBase.WinKeywords.ToString().Trim();
+ if (string.IsNullOrEmpty(value))
+ continue;
+ results.Add(value);
+ }
+ }
+ return results.AsReadOnly();
+ }
+
+ internal static int? GetWidth(ExifDirectoryBase[]? exifBaseDirectories)
+ {
+ int? result = null;
+ // public const int TagImageWidth = 256;
+ if (exifBaseDirectories is not null)
+ {
+ foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
+ {
+ result = exifDirectoryBase?.ImageWidthValue;
+ if (result is not null)
+ break;
+ }
+ }
+ return result;
+ }
+
+ internal static int? GetHeight(ExifDirectoryBase[]? exifBaseDirectories)
+ {
+ int? result = null;
+ // public const int TagImageHeight = 257;
+ if (exifBaseDirectories is not null)
+ {
+ foreach (ExifDirectoryBase exifDirectoryBase in exifBaseDirectories)
+ {
+ result = exifDirectoryBase?.ImageHeightValue;
+ if (result is not null)
+ break;
+ }
+ }
+ return result;
+ }
+
+#pragma warning disable CA1416
+
+ internal static DateTime? GetDateTime(string dateTimeFormat, string? value)
+ {
+ DateTime? result;
+ string alternateFormat = "ddd MMM dd HH:mm:ss yyyy";
+ if (value is not null && DateTime.TryParse(value, out DateTime dateTime))
+ result = dateTime;
+ else if (value is not null && value.Length == dateTimeFormat.Length && DateTime.TryParseExact(value, dateTimeFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime))
+ result = dateTime;
+ else if (value is not null && value.Length == alternateFormat.Length && DateTime.TryParseExact(value, alternateFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime))
+ result = dateTime;
+ else
+ result = null;
+ return result;
+ }
+
+#pragma warning restore CA1416
+
+}
\ No newline at end of file
diff --git a/Shared/Models/Stateless/IMetaBase.cs b/Shared/Models/Stateless/IMetaBase.cs
new file mode 100644
index 0000000..f713a0c
--- /dev/null
+++ b/Shared/Models/Stateless/IMetaBase.cs
@@ -0,0 +1,74 @@
+using System.Collections.ObjectModel;
+
+namespace View_by_Distance.Shared.Models.Stateless;
+
+public interface IMetaBase
+{
+
+ public static string DateTimeFormat() =>
+ "yyyy:MM:dd HH:mm:ss";
+
+ public static string? GetMaker(ExifDirectory? exifDirectory) =>
+ MetaBase.GetMaker(exifDirectory?.ExifBaseDirectories);
+
+ public static string? GetModel(ExifDirectory? exifDirectory) =>
+ MetaBase.GetModel(exifDirectory?.ExifBaseDirectories);
+
+ public static int? GetOrientation(ExifDirectory? exifDirectory) =>
+ MetaBase.GetOrientation(exifDirectory?.ExifBaseDirectories);
+
+ public static int? GetWidth(ExifDirectoryBase[]? exifBaseDirectories) =>
+ MetaBase.GetWidth(exifBaseDirectories);
+
+ public static int? GetHeight(ExifDirectoryBase[]? exifBaseDirectories) =>
+ MetaBase.GetHeight(exifBaseDirectories);
+
+ public static string? GetMaker(ExifDirectoryBase[]? exifBaseDirectories) =>
+ MetaBase.GetMaker(exifBaseDirectories);
+
+ public static string? GetModel(ExifDirectoryBase[]? exifBaseDirectories) =>
+ MetaBase.GetModel(exifBaseDirectories);
+
+ public static DateTime? GetDateTime(string dateTimeFormat, string? value) =>
+ MetaBase.GetDateTime(dateTimeFormat, value);
+
+ public static int? GetOrientation(ExifDirectoryBase[]? exifBaseDirectories) =>
+ MetaBase.GetOrientation(exifBaseDirectories);
+
+ public static ReadOnlyCollection GetKeywords(ExifDirectory? exifDirectory) =>
+ MetaBase.GetKeywords(exifDirectory?.ExifBaseDirectories);
+
+ public static ReadOnlyCollection GetKeywords(ExifDirectoryBase[]? exifBaseDirectories) =>
+ MetaBase.GetKeywords(exifBaseDirectories);
+
+ internal string TestStatic_DateTimeFormat() =>
+ DateTimeFormat();
+
+ internal string? TestStatic_GetMaker(ExifDirectory? exifDirectory) =>
+ GetMaker(exifDirectory);
+
+ internal string? TestStatic_GetModel(ExifDirectory? exifDirectory) =>
+ GetModel(exifDirectory);
+
+ internal static int? TestStatic_GetWidth(ExifDirectoryBase[]? exifBaseDirectories) =>
+ GetWidth(exifBaseDirectories);
+
+ internal static int? TestStatic_GetHeight(ExifDirectoryBase[]? exifBaseDirectories) =>
+ GetHeight(exifBaseDirectories);
+
+ internal static string? TestStatic_GetMaker(ExifDirectoryBase[]? exifBaseDirectories) =>
+ GetMaker(exifBaseDirectories);
+
+ internal static string? TestStatic_GetModel(ExifDirectoryBase[]? exifBaseDirectories) =>
+ GetModel(exifBaseDirectories);
+
+ internal static DateTime? TestStatic_GetDateTime(string dateTimeFormat, string? value) =>
+ GetDateTime(dateTimeFormat, value);
+
+ internal static int? TestStatic_GetOrientation(ExifDirectoryBase[]? exifBaseDirectories) =>
+ GetOrientation(exifBaseDirectories);
+
+ internal static ReadOnlyCollection TestStatic_GetKeywords(ExifDirectoryBase[]? exifBaseDirectories) =>
+ GetKeywords(exifBaseDirectories);
+
+}
\ No newline at end of file