Skip to content

Commit

Permalink
OX Quiz Table (#27)
Browse files Browse the repository at this point in the history
  • Loading branch information
Zintixx authored Jun 24, 2024
1 parent 364efa8 commit c843966
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 2 deletions.
2 changes: 1 addition & 1 deletion Maple2.File.Parser/Maple2.File.Parser.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
<PackageTags>MapleStory2, File, Parser, m2d, xml</PackageTags>
<!-- Use following lines to write the generated files to disk. -->
<EmitCompilerGeneratedFiles Condition=" '$(Configuration)' == 'Debug' ">true</EmitCompilerGeneratedFiles>
<PackageVersion>2.1.20</PackageVersion>
<PackageVersion>2.1.21</PackageVersion>
<TargetFramework>net8.0</TargetFramework>
<PackageReadmeFile>README.md</PackageReadmeFile>
<ImplicitUsings>enable</ImplicitUsings>
Expand Down
13 changes: 13 additions & 0 deletions Maple2.File.Parser/ServerTableParser.cs
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ public class ServerTableParser {
private readonly XmlSerializer adventureIdExpTableSerializer;
private readonly XmlSerializer adventureExpTableSerializer;
private readonly XmlSerializer timeEventDataSerializer;
private readonly XmlSerializer oxQuizSerializer;

public ServerTableParser(M2dReader xmlReader) {
this.xmlReader = xmlReader;
Expand Down Expand Up @@ -69,6 +70,7 @@ public ServerTableParser(M2dReader xmlReader) {
adventureIdExpTableSerializer = new XmlSerializer(typeof(AdventureIdExpTableRoot));
adventureExpTableSerializer = new XmlSerializer(typeof(AdventureExpTableRoot));
timeEventDataSerializer = new XmlSerializer(typeof(TimeEventDataRoot));
oxQuizSerializer = new XmlSerializer(typeof(OxQuizRoot));

// var seen = new HashSet<string>();
// this.bankTypeSerializer.UnknownAttribute += (sender, args) => {
Expand Down Expand Up @@ -540,4 +542,15 @@ public ServerTableParser(M2dReader xmlReader) {
yield return (entry.id, entry);
}
}

public IEnumerable<(int Id, OxQuiz Quiz)> ParseOxQuiz() {
string xml = Sanitizer.RemoveEmpty(xmlReader.GetString(xmlReader.GetEntry("table/Server/OxQuiz.xml")));
var reader = XmlReader.Create(new StringReader(xml));
var data = oxQuizSerializer.Deserialize(reader) as OxQuizRoot;
Debug.Assert(data != null);

foreach (OxQuiz entry in data.OxQuiz) {
yield return (entry.quizID, entry);
}
}
}
20 changes: 20 additions & 0 deletions Maple2.File.Parser/Xml/Table/Server/OxQuiz.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
using System.Xml.Serialization;
using M2dXmlGenerator;

namespace Maple2.File.Parser.Xml.Table.Server;

// ./data/server/table/Server/OxQuiz.xml
[XmlRoot("ms2")]
public class OxQuizRoot {
[XmlElement] public List<OxQuiz> OxQuiz;
}

public class OxQuiz {
[XmlAttribute] public int quizID;
[XmlAttribute] public int categoryID;
[XmlAttribute] public string categoryStr = string.Empty;
[XmlAttribute] public string quizStr = string.Empty;
[XmlAttribute] public int level;
[XmlAttribute] public bool answer;
[XmlAttribute] public string answerStr = string.Empty;
}
10 changes: 9 additions & 1 deletion Maple2.File.Tests/ServerTableParserTest.cs
Original file line number Diff line number Diff line change
Expand Up @@ -332,9 +332,17 @@ public void TestAdventureExp() {
public void TestTimeEventData() {
var parser = new ServerTableParser(TestUtils.ServerReader);

var timedEventData = parser.ParseTimeEventData();
foreach ((_, _) in parser.ParseTimeEventData()) {
continue;
}
}

[TestMethod]
public void TestOxQuiz() {
var parser = new ServerTableParser(TestUtils.ServerReader);

foreach ((_, _) in parser.ParseOxQuiz()) {
continue;
}
}
}

0 comments on commit c843966

Please sign in to comment.