using System; using System.Collections.Generic; using SabreTools.Core; using SabreTools.DatItems; namespace SabreTools.DatFiles.Formats { /// /// Represents parsing and writing of an AttractMode DAT /// internal partial class AttractMode : DatFile { /// protected override ItemType[] GetSupportedTypes() { return [ ItemType.Rom ]; } /// protected override List? GetMissingRequiredFields(DatItem datItem) { var missingFields = new List(); // Check item name if (string.IsNullOrEmpty(datItem.GetName())) missingFields.Add(Models.Metadata.Rom.NameKey); return missingFields; } /// public override bool WriteToFile(string outfile, bool ignoreblanks = false, bool throwOnError = false) { try { logger.User($"Writing to '{outfile}'..."); // Serialize the input file var metadata = ConvertMetadata(ignoreblanks); var metadataFile = new Serialization.CrossModel.AttractMode().Deserialize(metadata); if (!(new Serialization.Files.AttractMode().Serialize(metadataFile, outfile))) { logger.Warning($"File '{outfile}' could not be written! See the log for more details."); return false; } } catch (Exception ex) when (!throwOnError) { logger.Error(ex); return false; } logger.User($"'{outfile}' written!{Environment.NewLine}"); return true; } } }