From 6eb915c129fc90c6f4c82ae097dd6ffad5239efc Mon Sep 17 00:00:00 2001 From: chai Date: Mon, 25 Jan 2021 14:28:30 +0800 Subject: +scripts --- .../Assets/Scripts/XUtliPoolLib/ExpeditionTable.cs | 209 +++++++++++++++++++++ 1 file changed, 209 insertions(+) create mode 100644 Client/Assets/Scripts/XUtliPoolLib/ExpeditionTable.cs (limited to 'Client/Assets/Scripts/XUtliPoolLib/ExpeditionTable.cs') diff --git a/Client/Assets/Scripts/XUtliPoolLib/ExpeditionTable.cs b/Client/Assets/Scripts/XUtliPoolLib/ExpeditionTable.cs new file mode 100644 index 00000000..0722658b --- /dev/null +++ b/Client/Assets/Scripts/XUtliPoolLib/ExpeditionTable.cs @@ -0,0 +1,209 @@ +using System; + +namespace XUtliPoolLib +{ + public class ExpeditionTable : CVSReader + { + public ExpeditionTable.RowData[] Table = null; + + public class RowData + { + public int DNExpeditionID; + + public string DNExpeditionName; + + public uint[] ViewableDropList; + + public int RequiredLevel; + + public int PlayerNumber; + + public uint[] RandomSceneIDs; + + public int GuildLevel; + + public int Type; + + public int PlayerLeastNumber; + + public int Category; + + public uint DisplayLevel; + + public uint DisplayPPT; + + public int fastmatch; + + public int FMARobotTime; + + public SeqListRef CostItem; + + public uint LevelSealType; + + public int CanHelp; + + public int AutoSelectPriority; + + public SeqListRef CostType; + + public int CostCountType; + + public SeqRef ServerOpenTime; + + public int SortID; + + public SeqRef UseTicket; + + public SeqRef Stars; + + public bool isCrossServerInvite; + + public bool ShowPPT; + } + + public ExpeditionTable.RowData GetByDNExpeditionID(int key) + { + bool flag = this.Table == null || this.Table.Length == 0; + ExpeditionTable.RowData result; + if (flag) + { + result = null; + } + else + { + result = this.BinarySearchDNExpeditionID(key); + } + return result; + } + + private ExpeditionTable.RowData BinarySearchDNExpeditionID(int key) + { + int num = 0; + int num2 = this.Table.Length - 1; + ExpeditionTable.RowData rowData; + ExpeditionTable.RowData rowData2; + ExpeditionTable.RowData rowData3; + for (;;) + { + rowData = this.Table[num]; + bool flag = rowData.DNExpeditionID == key; + if (flag) + { + break; + } + rowData2 = this.Table[num2]; + bool flag2 = rowData2.DNExpeditionID == key; + if (flag2) + { + goto Block_2; + } + bool flag3 = num2 - num <= 1; + if (flag3) + { + goto Block_3; + } + int num3 = num + (num2 - num) / 2; + rowData3 = this.Table[num3]; + bool flag4 = rowData3.DNExpeditionID.CompareTo(key) > 0; + if (flag4) + { + num2 = num3; + } + else + { + bool flag5 = rowData3.DNExpeditionID.CompareTo(key) < 0; + if (!flag5) + { + goto IL_B1; + } + num = num3; + } + if (num >= num2) + { + goto Block_6; + } + } + return rowData; + Block_2: + return rowData2; + Block_3: + return null; + IL_B1: + return rowData3; + Block_6: + return null; + } + + protected override void ReadLine(XBinaryReader reader) + { + ExpeditionTable.RowData rowData = new ExpeditionTable.RowData(); + base.Read(reader, ref rowData.DNExpeditionID, CVSReader.intParse); + this.columnno = 0; + base.Read(reader, ref rowData.DNExpeditionName, CVSReader.stringParse); + this.columnno = 1; + base.ReadArray(reader, ref rowData.ViewableDropList, CVSReader.uintParse); + this.columnno = 2; + base.Read(reader, ref rowData.RequiredLevel, CVSReader.intParse); + this.columnno = 3; + base.Read(reader, ref rowData.PlayerNumber, CVSReader.intParse); + this.columnno = 4; + base.ReadArray(reader, ref rowData.RandomSceneIDs, CVSReader.uintParse); + this.columnno = 5; + base.Read(reader, ref rowData.GuildLevel, CVSReader.intParse); + this.columnno = 6; + base.Read(reader, ref rowData.Type, CVSReader.intParse); + this.columnno = 7; + base.Read(reader, ref rowData.PlayerLeastNumber, CVSReader.intParse); + this.columnno = 9; + base.Read(reader, ref rowData.Category, CVSReader.intParse); + this.columnno = 10; + base.Read(reader, ref rowData.DisplayLevel, CVSReader.uintParse); + this.columnno = 12; + base.Read(reader, ref rowData.DisplayPPT, CVSReader.uintParse); + this.columnno = 13; + base.Read(reader, ref rowData.fastmatch, CVSReader.intParse); + this.columnno = 15; + base.Read(reader, ref rowData.FMARobotTime, CVSReader.intParse); + this.columnno = 16; + rowData.CostItem.Read(reader, this.m_DataHandler); + this.columnno = 17; + base.Read(reader, ref rowData.LevelSealType, CVSReader.uintParse); + this.columnno = 18; + base.Read(reader, ref rowData.CanHelp, CVSReader.intParse); + this.columnno = 19; + base.Read(reader, ref rowData.AutoSelectPriority, CVSReader.intParse); + this.columnno = 21; + rowData.CostType.Read(reader, this.m_DataHandler); + this.columnno = 23; + base.Read(reader, ref rowData.CostCountType, CVSReader.intParse); + this.columnno = 24; + rowData.ServerOpenTime.Read(reader, this.m_DataHandler); + this.columnno = 27; + base.Read(reader, ref rowData.SortID, CVSReader.intParse); + this.columnno = 29; + rowData.UseTicket.Read(reader, this.m_DataHandler); + this.columnno = 30; + rowData.Stars.Read(reader, this.m_DataHandler); + this.columnno = 31; + base.Read(reader, ref rowData.isCrossServerInvite, CVSReader.boolParse); + this.columnno = 32; + base.Read(reader, ref rowData.ShowPPT, CVSReader.boolParse); + this.columnno = 38; + this.Table[this.lineno] = rowData; + this.columnno = -1; + } + + protected override void OnClear(int lineCount) + { + bool flag = lineCount > 0; + if (flag) + { + this.Table = new ExpeditionTable.RowData[lineCount]; + } + else + { + this.Table = null; + } + } + } +} -- cgit v1.1-26-g67d0