public override void ReadData(ESPReader reader, long dataEnd) { while (reader.BaseStream.Position < dataEnd) { string subTag = reader.PeekTag(); switch (subTag) { case "EDID": if (EditorID == null) { EditorID = new SimpleSubrecord <String>(); } EditorID.ReadBinary(reader); break; case "FULL": if (Name == null) { Name = new SimpleSubrecord <String>(); } Name.ReadBinary(reader); break; case "DESC": if (Description == null) { Description = new SimpleSubrecord <String>(); } Description.ReadBinary(reader); break; case "XNAM": if (Relationships == null) { Relationships = new List <Relationship>(); } Relationship tempXNAM = new Relationship(); tempXNAM.ReadBinary(reader); Relationships.Add(tempXNAM); break; case "DATA": if (Data == null) { Data = new RaceData(); } Data.ReadBinary(reader); break; case "ONAM": if (OlderRace == null) { OlderRace = new RecordReference(); } OlderRace.ReadBinary(reader); break; case "YNAM": if (YoungerRace == null) { YoungerRace = new RecordReference(); } YoungerRace.ReadBinary(reader); break; case "NAM2": if (UnknownMarker == null) { UnknownMarker = new SubMarker(); } UnknownMarker.ReadBinary(reader); break; case "VTCK": if (DefaultVoices == null) { DefaultVoices = new RaceDefaultVoices(); } DefaultVoices.ReadBinary(reader); break; case "DNAM": if (DefaultHairStyles == null) { DefaultHairStyles = new RaceDefaultHairStyles(); } DefaultHairStyles.ReadBinary(reader); break; case "CNAM": if (DefaultHairColors == null) { DefaultHairColors = new RaceDefaultHairColors(); } DefaultHairColors.ReadBinary(reader); break; case "PNAM": if (FaceGenMainClamp == null) { FaceGenMainClamp = new SimpleSubrecord <Single>(); } FaceGenMainClamp.ReadBinary(reader); break; case "UNAM": if (FaceGenFaceClamp == null) { FaceGenFaceClamp = new SimpleSubrecord <Single>(); } FaceGenFaceClamp.ReadBinary(reader); break; case "ATTR": if (Unknown == null) { Unknown = new SimpleSubrecord <Byte[]>(); } Unknown.ReadBinary(reader); break; case "NAM0": if (HeadData == null) { HeadData = new RaceHeadData(); } HeadData.ReadBinary(reader); break; case "NAM1": if (BodyData == null) { BodyData = new RaceBodyData(); } BodyData.ReadBinary(reader); break; case "HNAM": if (Hairs == null) { Hairs = new FormArray(); } Hairs.ReadBinary(reader); break; case "ENAM": if (Eyes == null) { Eyes = new FormArray(); } Eyes.ReadBinary(reader); break; case "MNAM": if (MaleFaceGenData == null) { MaleFaceGenData = new FaceGenData(); } MaleFaceGenData.ReadBinary(reader); break; case "FNAM": if (FemaleFaceGenData == null) { FemaleFaceGenData = new FaceGenData(); } FemaleFaceGenData.ReadBinary(reader); break; default: throw new Exception(); } } }