diff --git a/SabreTools.DatFiles/DatHeader.cs b/SabreTools.DatFiles/DatHeader.cs index 7e80045b..f7e3bf13 100644 --- a/SabreTools.DatFiles/DatHeader.cs +++ b/SabreTools.DatFiles/DatHeader.cs @@ -213,80 +213,123 @@ namespace SabreTools.DatFiles /// DatHeader to get the values from public void ConditionalCopy(DatHeader? datHeader) { + // If the header is invalid, we can't do anything if (datHeader == null) return; + // Convert subheader values + if (datHeader._internal.ContainsKey(Models.Metadata.Header.CanOpenKey)) + { + var canOpen = datHeader.GetFieldValue(Models.Metadata.Header.CanOpenKey); + if (canOpen?.Extension != null) + SetFieldValue(Models.Metadata.Header.CanOpenKey, canOpen.Extension); + } + if (datHeader._internal.ContainsKey(Models.Metadata.Header.ImagesKey)) + { + var images = datHeader.GetFieldValue(Models.Metadata.Header.ImagesKey); + SetFieldValue(Models.Metadata.Header.ImagesKey, images); + } + if (datHeader._internal.ContainsKey(Models.Metadata.Header.InfosKey)) + { + var infos = datHeader.GetFieldValue(Models.Metadata.Header.InfosKey); + SetFieldValue(Models.Metadata.Header.InfosKey, infos); + } + if (datHeader._internal.ContainsKey(Models.Metadata.Header.NewDatKey)) + { + var newDat = datHeader.GetFieldValue(Models.Metadata.Header.NewDatKey); + SetFieldValue(Models.Metadata.Header.NewDatKey, newDat); + } + if (datHeader._internal.ContainsKey(Models.Metadata.Header.SearchKey)) + { + var search = datHeader.GetFieldValue(Models.Metadata.Header.SearchKey); + SetFieldValue(Models.Metadata.Header.SearchKey, search); + } + + // Selectively set non-standard fields if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(DatHeader.FileNameKey))) - SetFieldValue(DatHeader.FileNameKey, - datHeader.GetStringFieldValue(DatHeader.FileNameKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.NameKey))) - SetFieldValue(Models.Metadata.Header.NameKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.NameKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.DescriptionKey))) - SetFieldValue(Models.Metadata.Header.DescriptionKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.DescriptionKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.RootDirKey))) - SetFieldValue(Models.Metadata.Header.RootDirKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.RootDirKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.CategoryKey))) - SetFieldValue(Models.Metadata.Header.CategoryKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.CategoryKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.VersionKey))) - SetFieldValue(Models.Metadata.Header.VersionKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.VersionKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.DateKey))) - SetFieldValue(Models.Metadata.Header.DateKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.DateKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.AuthorKey))) - SetFieldValue(Models.Metadata.Header.AuthorKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.AuthorKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.EmailKey))) - SetFieldValue(Models.Metadata.Header.EmailKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.EmailKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.HomepageKey))) - SetFieldValue(Models.Metadata.Header.HomepageKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.HomepageKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.UrlKey))) - SetFieldValue(Models.Metadata.Header.UrlKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.UrlKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.CommentKey))) - SetFieldValue(Models.Metadata.Header.CommentKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.CommentKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.HeaderKey))) - SetFieldValue(Models.Metadata.Header.HeaderKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.HeaderKey)); - - if (!string.IsNullOrEmpty(datHeader.GetStringFieldValue(Models.Metadata.Header.TypeKey))) - SetFieldValue(Models.Metadata.Header.TypeKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.TypeKey)); - - if (datHeader.GetStringFieldValue(Models.Metadata.Header.ForceMergingKey).AsEnumValue() != MergingFlag.None) - SetFieldValue(Models.Metadata.Header.ForceMergingKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.ForceMergingKey).AsEnumValue().AsStringValue()); - - if (datHeader.GetStringFieldValue(Models.Metadata.Header.ForceNodumpKey).AsEnumValue() != NodumpFlag.None) - SetFieldValue(Models.Metadata.Header.ForceNodumpKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.ForceNodumpKey).AsEnumValue().AsStringValue()); - - if (datHeader.GetStringFieldValue(Models.Metadata.Header.ForcePackingKey).AsEnumValue() != PackingFlag.None) - SetFieldValue(Models.Metadata.Header.ForcePackingKey, - datHeader.GetStringFieldValue(Models.Metadata.Header.ForcePackingKey).AsEnumValue().AsStringValue()); - + SetFieldValue(DatHeader.FileNameKey, datHeader.GetStringFieldValue(DatHeader.FileNameKey)); if (datHeader.GetFieldValue(DatHeader.DatFormatKey) != 0x00) - SetFieldValue(DatHeader.DatFormatKey, - datHeader.GetFieldValue(DatHeader.DatFormatKey)); + SetFieldValue(DatHeader.DatFormatKey, datHeader.GetFieldValue(DatHeader.DatFormatKey)); + + // Selectively set all possible fields -- TODO: Figure out how to make this less manual + if (GetStringFieldValue(Models.Metadata.Header.AuthorKey) == null) + SetFieldValue(Models.Metadata.Header.AuthorKey, datHeader.GetStringFieldValue(Models.Metadata.Header.AuthorKey)); + if (GetStringFieldValue(Models.Metadata.Header.BiosModeKey).AsEnumValue() == MergingFlag.None) + SetFieldValue(Models.Metadata.Header.BiosModeKey, datHeader.GetStringFieldValue(Models.Metadata.Header.BiosModeKey).AsEnumValue().AsStringValue()); + if (GetStringFieldValue(Models.Metadata.Header.BuildKey) == null) + SetFieldValue(Models.Metadata.Header.BuildKey, datHeader.GetStringFieldValue(Models.Metadata.Header.BuildKey)); + if (GetStringFieldValue(Models.Metadata.Header.CategoryKey) == null) + SetFieldValue(Models.Metadata.Header.CategoryKey, datHeader.GetStringFieldValue(Models.Metadata.Header.CategoryKey)); + if (GetStringFieldValue(Models.Metadata.Header.CommentKey) == null) + SetFieldValue(Models.Metadata.Header.CommentKey, datHeader.GetStringFieldValue(Models.Metadata.Header.CommentKey)); + if (GetStringFieldValue(Models.Metadata.Header.DateKey) == null) + SetFieldValue(Models.Metadata.Header.DateKey, datHeader.GetStringFieldValue(Models.Metadata.Header.DateKey)); + if (GetStringFieldValue(Models.Metadata.Header.DatVersionKey) == null) + SetFieldValue(Models.Metadata.Header.DatVersionKey, datHeader.GetStringFieldValue(Models.Metadata.Header.DatVersionKey)); + if (GetBoolFieldValue(Models.Metadata.Header.DebugKey) == null) + SetFieldValue(Models.Metadata.Header.DebugKey, datHeader.GetBoolFieldValue(Models.Metadata.Header.DebugKey)); + if (GetStringFieldValue(Models.Metadata.Header.DescriptionKey) == null) + SetFieldValue(Models.Metadata.Header.DescriptionKey, datHeader.GetStringFieldValue(Models.Metadata.Header.DescriptionKey)); + if (GetStringFieldValue(Models.Metadata.Header.EmailKey) == null) + SetFieldValue(Models.Metadata.Header.EmailKey, datHeader.GetStringFieldValue(Models.Metadata.Header.EmailKey)); + if (GetStringFieldValue(Models.Metadata.Header.EmulatorVersionKey) == null) + SetFieldValue(Models.Metadata.Header.EmulatorVersionKey, datHeader.GetStringFieldValue(Models.Metadata.Header.EmulatorVersionKey)); + if (GetStringFieldValue(Models.Metadata.Header.ForceMergingKey).AsEnumValue() == MergingFlag.None) + SetFieldValue(Models.Metadata.Header.ForceMergingKey, datHeader.GetStringFieldValue(Models.Metadata.Header.ForceMergingKey).AsEnumValue().AsStringValue()); + if (GetStringFieldValue(Models.Metadata.Header.ForceNodumpKey).AsEnumValue() == NodumpFlag.None) + SetFieldValue(Models.Metadata.Header.ForceNodumpKey, datHeader.GetStringFieldValue(Models.Metadata.Header.ForceNodumpKey).AsEnumValue().AsStringValue()); + if (GetStringFieldValue(Models.Metadata.Header.ForcePackingKey).AsEnumValue() == PackingFlag.None) + SetFieldValue(Models.Metadata.Header.ForcePackingKey, datHeader.GetStringFieldValue(Models.Metadata.Header.ForcePackingKey).AsEnumValue().AsStringValue()); + if (GetBoolFieldValue(Models.Metadata.Header.ForceZippingKey) == null) + SetFieldValue(Models.Metadata.Header.ForceZippingKey, datHeader.GetBoolFieldValue(Models.Metadata.Header.ForceZippingKey)); + if (GetStringFieldValue(Models.Metadata.Header.HeaderKey) == null) + SetFieldValue(Models.Metadata.Header.HeaderKey, datHeader.GetStringFieldValue(Models.Metadata.Header.HeaderKey)); + if (GetStringFieldValue(Models.Metadata.Header.HomepageKey) == null) + SetFieldValue(Models.Metadata.Header.HomepageKey, datHeader.GetStringFieldValue(Models.Metadata.Header.HomepageKey)); + if (GetStringFieldValue(Models.Metadata.Header.IdKey) == null) + SetFieldValue(Models.Metadata.Header.IdKey, datHeader.GetStringFieldValue(Models.Metadata.Header.IdKey)); + if (GetStringFieldValue(Models.Metadata.Header.ImFolderKey) == null) + SetFieldValue(Models.Metadata.Header.ImFolderKey, datHeader.GetStringFieldValue(Models.Metadata.Header.ImFolderKey)); + if (GetBoolFieldValue(Models.Metadata.Header.LockBiosModeKey) == null) + SetFieldValue(Models.Metadata.Header.LockBiosModeKey, datHeader.GetBoolFieldValue(Models.Metadata.Header.LockBiosModeKey)); + if (GetBoolFieldValue(Models.Metadata.Header.LockRomModeKey) == null) + SetFieldValue(Models.Metadata.Header.LockRomModeKey, datHeader.GetBoolFieldValue(Models.Metadata.Header.LockRomModeKey)); + if (GetBoolFieldValue(Models.Metadata.Header.LockSampleModeKey) == null) + SetFieldValue(Models.Metadata.Header.LockSampleModeKey, datHeader.GetBoolFieldValue(Models.Metadata.Header.LockSampleModeKey)); + if (GetStringFieldValue(Models.Metadata.Header.MameConfigKey) == null) + SetFieldValue(Models.Metadata.Header.MameConfigKey, datHeader.GetStringFieldValue(Models.Metadata.Header.MameConfigKey)); + if (GetStringFieldValue(Models.Metadata.Header.NameKey) == null) + SetFieldValue(Models.Metadata.Header.NameKey, datHeader.GetStringFieldValue(Models.Metadata.Header.NameKey)); + if (GetStringFieldValue(Models.Metadata.Header.NotesKey) == null) + SetFieldValue(Models.Metadata.Header.NotesKey, datHeader.GetStringFieldValue(Models.Metadata.Header.NotesKey)); + if (GetStringFieldValue(Models.Metadata.Header.PluginKey) == null) + SetFieldValue(Models.Metadata.Header.PluginKey, datHeader.GetStringFieldValue(Models.Metadata.Header.PluginKey)); + if (GetStringFieldValue(Models.Metadata.Header.RefNameKey) == null) + SetFieldValue(Models.Metadata.Header.RefNameKey, datHeader.GetStringFieldValue(Models.Metadata.Header.RefNameKey)); + if (GetStringFieldValue(Models.Metadata.Header.RomModeKey).AsEnumValue() == MergingFlag.None) + SetFieldValue(Models.Metadata.Header.RomModeKey, datHeader.GetStringFieldValue(Models.Metadata.Header.RomModeKey).AsEnumValue().AsStringValue()); + if (GetStringFieldValue(Models.Metadata.Header.RomTitleKey) == null) + SetFieldValue(Models.Metadata.Header.RomTitleKey, datHeader.GetStringFieldValue(Models.Metadata.Header.RomTitleKey)); + if (GetStringFieldValue(Models.Metadata.Header.RootDirKey) == null) + SetFieldValue(Models.Metadata.Header.RootDirKey, datHeader.GetStringFieldValue(Models.Metadata.Header.RootDirKey)); + if (GetStringFieldValue(Models.Metadata.Header.SampleModeKey).AsEnumValue() == MergingFlag.None) + SetFieldValue(Models.Metadata.Header.SampleModeKey, datHeader.GetStringFieldValue(Models.Metadata.Header.SampleModeKey).AsEnumValue().AsStringValue()); + if (GetStringFieldValue(Models.Metadata.Header.SchemaLocationKey) == null) + SetFieldValue(Models.Metadata.Header.SchemaLocationKey, datHeader.GetStringFieldValue(Models.Metadata.Header.SchemaLocationKey)); + if (GetStringFieldValue(Models.Metadata.Header.ScreenshotsHeightKey) == null) + SetFieldValue(Models.Metadata.Header.ScreenshotsHeightKey, datHeader.GetStringFieldValue(Models.Metadata.Header.ScreenshotsHeightKey)); + if (GetStringFieldValue(Models.Metadata.Header.ScreenshotsWidthKey) == null) + SetFieldValue(Models.Metadata.Header.ScreenshotsWidthKey, datHeader.GetStringFieldValue(Models.Metadata.Header.ScreenshotsWidthKey)); + if (GetStringFieldValue(Models.Metadata.Header.SystemKey) == null) + SetFieldValue(Models.Metadata.Header.SystemKey, datHeader.GetStringFieldValue(Models.Metadata.Header.SystemKey)); + if (GetStringFieldValue(Models.Metadata.Header.TimestampKey) == null) + SetFieldValue(Models.Metadata.Header.TimestampKey, datHeader.GetStringFieldValue(Models.Metadata.Header.TimestampKey)); + if (GetStringFieldValue(Models.Metadata.Header.TypeKey) == null) + SetFieldValue(Models.Metadata.Header.TypeKey, datHeader.GetStringFieldValue(Models.Metadata.Header.TypeKey)); + if (GetStringFieldValue(Models.Metadata.Header.UrlKey) == null) + SetFieldValue(Models.Metadata.Header.UrlKey, datHeader.GetStringFieldValue(Models.Metadata.Header.UrlKey)); + if (GetStringFieldValue(Models.Metadata.Header.VersionKey) == null) + SetFieldValue(Models.Metadata.Header.VersionKey, datHeader.GetStringFieldValue(Models.Metadata.Header.VersionKey)); } #endregion