public bool GetDataFromTxtFile(string fileName, bool multiSelect) { mainForm.SetCurrentStatus("Getting lines..."); var lines = File.ReadAllLines(fileName); Dictionary <long, Packet.PacketTypes> packetIndexes = new Dictionary <long, Packet.PacketTypes>(); BuildVersions buildVersion = LineGetters.GetBuildVersion(lines); if (!IsTxtFileValidForParse(fileName, lines, buildVersion)) { return(false); } if (!multiSelect) { creaturesDict.Clear(); } mainForm.SetCurrentStatus("Searching for packet indexes in lines..."); Parallel.For(0, lines.Length, index => { Packet.PacketTypes packetType = Packet.GetPacketTypeFromLine(lines[index]); if (packetType == Packet.PacketTypes.SMSG_UPDATE_OBJECT && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_UPDATE_OBJECT); } else if (packetType == Packet.PacketTypes.SMSG_AI_REACTION && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_AI_REACTION); } else if (packetType == Packet.PacketTypes.SMSG_SPELL_START && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_START); } else if (packetType == Packet.PacketTypes.SMSG_CHAT && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_CHAT); } else if (packetType == Packet.PacketTypes.SMSG_ON_MONSTER_MOVE && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_ON_MONSTER_MOVE); } else if (packetType == Packet.PacketTypes.SMSG_ATTACK_STOP && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_ATTACK_STOP); } }); mainForm.SetCurrentStatus("Parsing SMSG_UPDATE_OBJECT packets..."); foreach (var value in packetIndexes) { if (value.Value == Packet.PacketTypes.SMSG_UPDATE_OBJECT) { Parallel.ForEach(UpdateObjectPacket.ParseObjectUpdatePacket(lines, value.Key, buildVersion, 0), packet => { lock (creaturesDict) { if (!creaturesDict.ContainsKey(packet.guid)) { creaturesDict.Add(packet.guid, new Creature(packet)); } else { creaturesDict[packet.guid].UpdateCreature(packet); } } }); } } Parallel.ForEach(creaturesDict.Values, creature => { creature.name = MainForm.GetCreatureNameByEntry(creature.entry); }); mainForm.SetCurrentStatus("Parsing SMSG_SPELL_START packets..."); Parallel.ForEach(packetIndexes, value => { if (value.Value == Packet.PacketTypes.SMSG_SPELL_START) { SpellStartPacket spellPacket = SpellStartPacket.ParseSpellStartPacket(lines, value.Key, buildVersion, value.Value); if (spellPacket.spellId == 0) { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(spellPacket.casterGuid)) { if (!creaturesDict[spellPacket.casterGuid].castedSpells.ContainsKey(spellPacket.spellId)) { creaturesDict[spellPacket.casterGuid].castedSpells.Add(spellPacket.spellId, new Spell(spellPacket)); } else { creaturesDict[spellPacket.casterGuid].UpdateSpells(spellPacket); } } } } }); mainForm.SetCurrentStatus("Parsing SMSG_AI_REACTION packets..."); Parallel.ForEach(packetIndexes, value => { if (value.Value == Packet.PacketTypes.SMSG_AI_REACTION) { AIReactionPacket reactionPacket = AIReactionPacket.ParseAIReactionPacket(lines, value.Key, buildVersion); if (reactionPacket.creatureGuid == "") { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(reactionPacket.creatureGuid)) { if (creaturesDict[reactionPacket.creatureGuid].combatStartTime == TimeSpan.Zero || creaturesDict[reactionPacket.creatureGuid].combatStartTime < reactionPacket.packetSendTime) { creaturesDict[reactionPacket.creatureGuid].combatStartTime = reactionPacket.packetSendTime; } creaturesDict[reactionPacket.creatureGuid].UpdateCombatSpells(reactionPacket); } } } }); mainForm.SetCurrentStatus("Parsing SMSG_CHAT packets..."); Parallel.ForEach(packetIndexes, value => { if (value.Value == Packet.PacketTypes.SMSG_CHAT) { ChatPacket chatPacket = ChatPacket.ParseChatPacket(lines, value.Key, buildVersion); if (chatPacket.creatureGuid == "") { return; } lock (creaturesDict) { Parallel.ForEach(creaturesDict, creature => { if (creature.Value.entry == chatPacket.creatureEntry) { CreatureText text = new CreatureText(chatPacket, true); if (Math.Floor(creature.Value.combatStartTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) || Math.Floor(creature.Value.combatStartTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) + 1 || Math.Floor(creature.Value.combatStartTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) - 1) { lock (creatureTextsDict) { if (creatureTextsDict.ContainsKey(chatPacket.creatureEntry) && creatureTextsDict[chatPacket.creatureEntry].Count(x => x.creatureText == text.creatureText) == 0) { creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, true)); } else if (!creatureTextsDict.ContainsKey(chatPacket.creatureEntry)) { creatureTextsDict.Add(chatPacket.creatureEntry, new List <CreatureText>()); creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, true)); } } } if (Math.Floor(creature.Value.deathTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) || Math.Floor(creature.Value.deathTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) + 1 || Math.Floor(creature.Value.deathTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) - 1) { lock (creatureTextsDict) { if (creatureTextsDict.ContainsKey(chatPacket.creatureEntry) && creatureTextsDict[chatPacket.creatureEntry].Count(x => x.creatureText == text.creatureText) == 0) { creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, false, true)); } else if (!creatureTextsDict.ContainsKey(chatPacket.creatureEntry)) { creatureTextsDict.Add(chatPacket.creatureEntry, new List <CreatureText>()); creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, false, true)); } } } } }); } } }); mainForm.SetCurrentStatus("Parsing SMSG_ON_MONSTER_MOVE and SMSG_ATTACK_STOP packets..."); Parallel.ForEach(packetIndexes, value => { switch (value.Value) { case Packet.PacketTypes.SMSG_ON_MONSTER_MOVE: { MonsterMovePacket movePacket = MonsterMovePacket.ParseMovementPacket(lines, value.Key, buildVersion, 0); if (movePacket.creatureGuid == "") { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(movePacket.creatureGuid)) { creaturesDict[movePacket.creatureGuid].UpdateSpellsByMovementPacket(movePacket); } } break; } case Packet.PacketTypes.SMSG_ATTACK_STOP: { AttackStopPacket attackStopPacket = AttackStopPacket.ParseAttackStopkPacket(lines, value.Key, buildVersion); if (attackStopPacket.creatureGuid == "") { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(attackStopPacket.creatureGuid)) { creaturesDict[attackStopPacket.creatureGuid].UpdateSpellsByAttackStopPacket(attackStopPacket); if (attackStopPacket.nowDead) { creaturesDict[attackStopPacket.creatureGuid].deathTime = attackStopPacket.packetSendTime; } } } break; } } }); Parallel.ForEach(creaturesDict, creature => { creature.Value.RemoveNonCombatCastTimes(); }); Parallel.ForEach(creaturesDict, creature => { creature.Value.CreateCombatCastTimings(); }); Parallel.ForEach(creaturesDict, creature => { creature.Value.CreateDeathSpells(); }); if (mainForm.checkBox_CreatureScriptsCreator_CreateDataFile.Checked) { BinaryFormatter binaryFormatter = new BinaryFormatter(); if (!multiSelect) { using (FileStream fileStream = new FileStream(fileName.Replace("_parsed.txt", "_script_packets.dat"), FileMode.OpenOrCreate)) { Dictionary <uint, object> dictToSerialize = new Dictionary <uint, object> { { 0, creaturesDict }, { 1, creatureTextsDict } }; binaryFormatter.Serialize(fileStream, dictToSerialize); } } else { using (FileStream fileStream = new FileStream(fileName.Replace("_parsed.txt", "multi_selected_script_packets.dat"), FileMode.OpenOrCreate)) { Dictionary <uint, object> dictToSerialize = new Dictionary <uint, object> { { 0, creaturesDict }, { 1, creatureTextsDict } }; binaryFormatter.Serialize(fileStream, dictToSerialize); } } } mainForm.SetCurrentStatus(""); return(true); }
public bool GetDataFromSniffFile(string fileName) { mainForm.SetCurrentStatus("Loading DBC..."); DBC.DBC.Load(); mainForm.SetCurrentStatus("Getting lines..."); var lines = File.ReadAllLines(fileName); SortedDictionary <long, Packet> updateObjectPacketsDict = new SortedDictionary <long, Packet>(); SortedDictionary <long, Packet> movementPacketsDict = new SortedDictionary <long, Packet>(); SortedDictionary <long, Packet> spellPacketsDict = new SortedDictionary <long, Packet>(); SortedDictionary <long, Packet> auraPacketsDict = new SortedDictionary <long, Packet>(); SortedDictionary <long, Packet> emotePacketsDict = new SortedDictionary <long, Packet>(); buildVersion = LineGetters.GetBuildVersion(lines); if (buildVersion == BuildVersions.BUILD_UNKNOWN) { MessageBox.Show(fileName + " has non-supported build.", "File Error", MessageBoxButtons.OK, MessageBoxIcon.Error, MessageBoxDefaultButton.Button1); return(false); } mainForm.SetCurrentStatus("Searching for packet indexes in lines..."); Parallel.For(0, lines.Length, index => { if (Packet.GetPacketTypeFromLine(lines[index]) == Packet.PacketTypes.SMSG_UPDATE_OBJECT) { TimeSpan sendTime = LineGetters.GetTimeSpanFromLine(lines[index]); if (sendTime != TimeSpan.Zero) { lock (updateObjectPacketsDict) { if (!updateObjectPacketsDict.ContainsKey(index)) { updateObjectPacketsDict.Add(index, new Packet(Packet.PacketTypes.SMSG_UPDATE_OBJECT, sendTime, index, new List <object>())); } } } } else if (Packet.GetPacketTypeFromLine(lines[index]) == Packet.PacketTypes.SMSG_ON_MONSTER_MOVE) { TimeSpan sendTime = LineGetters.GetTimeSpanFromLine(lines[index]); if (sendTime != TimeSpan.Zero) { lock (movementPacketsDict) { if (!movementPacketsDict.ContainsKey(index)) { movementPacketsDict.Add(index, new Packet(Packet.PacketTypes.SMSG_ON_MONSTER_MOVE, sendTime, index, new List <object>())); } } } } else if (Properties.Settings.Default.Scripts && Packet.GetPacketTypeFromLine(lines[index]) == Packet.PacketTypes.SMSG_SPELL_START) { TimeSpan sendTime = LineGetters.GetTimeSpanFromLine(lines[index]); if (sendTime != TimeSpan.Zero) { lock (spellPacketsDict) { if (!spellPacketsDict.ContainsKey(index)) { spellPacketsDict.Add(index, new Packet(Packet.PacketTypes.SMSG_SPELL_START, sendTime, index, new List <object>())); } } } } else if (Properties.Settings.Default.Scripts && Packet.GetPacketTypeFromLine(lines[index]) == Packet.PacketTypes.SMSG_AURA_UPDATE) { TimeSpan sendTime = LineGetters.GetTimeSpanFromLine(lines[index]); if (sendTime != TimeSpan.Zero) { lock (auraPacketsDict) { if (!auraPacketsDict.ContainsKey(index)) { auraPacketsDict.Add(index, new Packet(Packet.PacketTypes.SMSG_AURA_UPDATE, sendTime, index, new List <object>())); } } } } else if (Properties.Settings.Default.Scripts && Packet.GetPacketTypeFromLine(lines[index]) == Packet.PacketTypes.SMSG_EMOTE) { TimeSpan sendTime = LineGetters.GetTimeSpanFromLine(lines[index]); if (sendTime != TimeSpan.Zero) { lock (emotePacketsDict) { if (!emotePacketsDict.ContainsKey(index)) { emotePacketsDict.Add(index, new Packet(Packet.PacketTypes.SMSG_EMOTE, sendTime, index, new List <object>())); } } } } }); creaturesDict.Clear(); mainForm.SetCurrentStatus("Parsing SMSG_UPDATE_OBJECT packets..."); Parallel.ForEach(updateObjectPacketsDict.Values.AsEnumerable(), packet => { Parallel.ForEach(UpdateObjectPacket.ParseObjectUpdatePacket(lines, packet.index, buildVersion).AsEnumerable(), updatePacket => { lock (updateObjectPacketsDict) { updateObjectPacketsDict.AddSourceFromUpdatePacket(updatePacket, packet.index); } lock (creaturesDict) { if (!creaturesDict.ContainsKey(updatePacket.creatureGuid)) { creaturesDict.Add(updatePacket.creatureGuid, new Creature(updatePacket)); } else { creaturesDict[updatePacket.creatureGuid].UpdateCreature(updatePacket); } } }); }); mainForm.SetCurrentStatus("Parsing SMSG_ON_MONSTER_MOVE packets..."); Parallel.ForEach(movementPacketsDict.Values.AsEnumerable(), packet => { MonsterMovePacket movePacket = MonsterMovePacket.ParseMovementPacket(lines, packet.index, buildVersion); if (movePacket.creatureGuid != "" && (movePacket.HasWaypoints() || movePacket.HasOrientation() || movePacket.HasJump())) { lock (movementPacketsDict) { movementPacketsDict.AddSourceFromMovementPacket(movePacket, packet.index); } lock (creaturesDict) { if (creaturesDict.ContainsKey(movePacket.creatureGuid)) { Creature creature = creaturesDict[movePacket.creatureGuid]; if (!creature.HasWaypoints() && movePacket.HasWaypoints()) { creature.AddWaypointsFromMovementPacket(movePacket); } else if (creature.HasWaypoints() && movePacket.HasOrientation() && !movePacket.HasWaypoints()) { creature.SortWaypoints(); creature.waypoints.Last().SetOrientation(movePacket.creatureOrientation); creature.waypoints.Last().SetOrientationSetTime(movePacket.packetSendTime); } else if (creature.HasWaypoints() && movePacket.HasWaypoints()) { if (creature.waypoints.Last().HasOrientation()) { creature.waypoints.Last().SetDelay((uint)((movePacket.packetSendTime - creature.waypoints.Last().orientationSetTime).TotalMilliseconds)); } creature.AddWaypointsFromMovementPacket(movePacket); } } } } }); if (Properties.Settings.Default.Scripts) { mainForm.SetCurrentStatus("Parsing SMSG_SPELL_START packets..."); Parallel.ForEach(spellPacketsDict.Values.AsEnumerable(), packet => { SpellStartPacket spellPacket = SpellStartPacket.ParseSpellStartPacket(lines, packet.index, buildVersion); if (spellPacket.spellId == 0) { return; } lock (spellPacketsDict) { spellPacketsDict.AddSourceFromSpellPacket(spellPacket, packet.index); } }); mainForm.SetCurrentStatus("Parsing SMSG_AURA_UPDATE packets..."); Parallel.ForEach(auraPacketsDict.Values.AsEnumerable(), packet => { Parallel.ForEach(AuraUpdatePacket.ParseAuraUpdatePacket(lines, packet.index, buildVersion).AsEnumerable(), auraPacket => { lock (auraPacketsDict) { auraPacketsDict.AddSourceFromAuraUpdatePacket(auraPacket, packet.index); } lock (creaturesDict) { if (creaturesDict.ContainsKey(auraPacket.unitGuid)) { Creature creature = creaturesDict[auraPacket.unitGuid]; creature.auras.Add(new Aura((uint)auraPacket.slot, (bool)auraPacket.HasAura, auraPacket.packetSendTime, auraPacket.spellId)); } } }); }); mainForm.SetCurrentStatus("Parsing SMSG_EMOTE packets..."); Parallel.ForEach(emotePacketsDict.Values.AsEnumerable(), packet => { EmotePacket emotePacket = EmotePacket.ParseEmotePacket(lines, packet.index, buildVersion); if (emotePacket.guid == "" || emotePacket.emoteId == 0) { return; } lock (emotePacketsDict) { emotePacketsDict.AddSourceFromEmotePacket(emotePacket, packet.index); } }); mainForm.SetCurrentStatus("Creating waypoint scripts for creatures..."); Parallel.ForEach(creaturesDict.Values.AsEnumerable(), creature => { if (creature.HasWaypoints()) { SortedDictionary <long, Packet> creaturePacketsDict = new SortedDictionary <long, Packet>(); foreach (var packet in updateObjectPacketsDict.Values.Where(packet => packet.HasCreatureWithGuid(creature.guid))) { creaturePacketsDict.Add(packet.index, packet); } foreach (var packet in movementPacketsDict.Values.Where(packet => packet.HasCreatureWithGuid(creature.guid))) { creaturePacketsDict.Add(packet.index, packet); } foreach (var packet in spellPacketsDict.Values.Where(packet => packet.HasCreatureWithGuid(creature.guid))) { creaturePacketsDict.Add(packet.index, packet); } foreach (var packet in auraPacketsDict.Values.Where(packet => packet.HasCreatureWithGuid(creature.guid))) { creaturePacketsDict.Add(packet.index, packet); } foreach (var packet in emotePacketsDict.Values.Where(packet => packet.HasCreatureWithGuid(creature.guid))) { creaturePacketsDict.Add(packet.index, packet); } List <WaypointScript> scriptsList = new List <WaypointScript>(); MonsterMovePacket startMovePacket = new MonsterMovePacket(); bool scriptsParsingStarted = false; foreach (Packet packet in creaturePacketsDict.Values) { switch (packet.packetType) { case Packet.PacketTypes.SMSG_ON_MONSTER_MOVE: { MonsterMovePacket movePacket = (MonsterMovePacket)packet.parsedPacketsList.First(); if (movePacket.HasWaypoints() && !scriptsParsingStarted) { startMovePacket = movePacket; scriptsParsingStarted = true; } else if (movePacket.HasWaypoints() && scriptsParsingStarted) { if (scriptsList.Count != 0) { creature.AddScriptsForWaypoints(scriptsList, startMovePacket, movePacket); scriptsList.Clear(); } startMovePacket = movePacket; } else if ((movePacket.HasOrientation() || movePacket.HasJump()) && scriptsParsingStarted) { scriptsList.Add(WaypointScript.GetScriptsFromMovementPacket(movePacket)); } break; } case Packet.PacketTypes.SMSG_UPDATE_OBJECT: { if (scriptsParsingStarted && packet.parsedPacketsList.Count != 0) { if (packet.parsedPacketsList.GetUpdatePacketForCreatureWithGuid(creature.guid) != null) { UpdateObjectPacket updatePacket = (UpdateObjectPacket)packet.parsedPacketsList.GetUpdatePacketForCreatureWithGuid(creature.guid); List <WaypointScript> updateScriptsList = WaypointScript.GetScriptsFromUpdatePacket(updatePacket); if (updateScriptsList.Count != 0) { scriptsList.AddRange(updateScriptsList); } } } break; } case Packet.PacketTypes.SMSG_SPELL_START: { if (scriptsParsingStarted) { SpellStartPacket spellPacket = (SpellStartPacket)packet.parsedPacketsList.First(); scriptsList.Add(WaypointScript.GetScriptsFromSpellPacket(spellPacket)); } break; } case Packet.PacketTypes.SMSG_AURA_UPDATE: { if (scriptsParsingStarted) { AuraUpdatePacket auraPacket = (AuraUpdatePacket)packet.parsedPacketsList.First(); if (auraPacket.HasAura == false) { scriptsList.Add(WaypointScript.GetScriptsFromAuraUpdatePacket(auraPacket, creature)); } } break; } case Packet.PacketTypes.SMSG_EMOTE: { if (scriptsParsingStarted) { EmotePacket emotePacket = (EmotePacket)packet.parsedPacketsList.First(); scriptsList.Add(WaypointScript.GetScriptsFromEmotePacket(emotePacket)); } break; } } } } }); } mainForm.SetCurrentStatus(""); return(true); }
public static string ParsePlayerCastedSpells(string fileName, string playerGuid) { if (!DBC.DBC.IsLoaded()) { DBC.DBC.Load(); } var lines = File.ReadAllLines(fileName); string outputLine = ""; Dictionary <long, Packet.PacketTypes> packetIndexes = new Dictionary <long, Packet.PacketTypes>(); Dictionary <uint, TimeSpan> spellsDictionary = new Dictionary <uint, TimeSpan>(); BuildVersions buildVersion = LineGetters.GetBuildVersion(lines); if (buildVersion == BuildVersions.BUILD_UNKNOWN) { MessageBox.Show(fileName + " has non-supported build.", "File Error", MessageBoxButtons.OK, MessageBoxIcon.Error, MessageBoxDefaultButton.Button1); return(""); } Parallel.For(0, lines.Length, index => { if (lines[index].Contains("SMSG_SPELL_START") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_START); } else if (lines[index].Contains("SMSG_SPELL_GO") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_GO); } }); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { if (value.Value == Packet.PacketTypes.SMSG_SPELL_START || value.Value == Packet.PacketTypes.SMSG_SPELL_GO) { SpellStartPacket spellPacket = SpellStartPacket.ParseSpellStartPacket(lines, value.Key, buildVersion, true); if (spellPacket.spellId == 0 || spellPacket.casterGuid != playerGuid) { return; } lock (spellsDictionary) { if (!spellsDictionary.ContainsKey(spellPacket.spellId)) { spellsDictionary.Add(spellPacket.spellId, spellPacket.spellCastStartTime); } } } }); spellsDictionary = spellsDictionary.OrderBy(x => x.Value).ToDictionary(x => x.Key, x => x.Value); outputLine += "Spells casted by player with guid \"" + playerGuid + "\"" + "\r\n"; foreach (var spell in spellsDictionary) { outputLine += "Spell Id: " + spell.Key + " (" + Spell.GetSpellName(spell.Key) + "), Cast Time: " + spell.Value.ToString() + "\r\n"; } return(outputLine); }
public bool GetDataFromSniffFile(string fileName) { mainForm.SetCurrentStatus("Loading DBC..."); DBC.DBC.Load(); mainForm.SetCurrentStatus("Getting lines..."); var lines = File.ReadAllLines(fileName); Dictionary <long, Packet.PacketTypes> packetIndexes = new Dictionary <long, Packet.PacketTypes>(); buildVersion = LineGetters.GetBuildVersion(lines); if (buildVersion == BuildVersions.BUILD_UNKNOWN) { MessageBox.Show(fileName + " has non-supported build.", "File Error", MessageBoxButtons.OK, MessageBoxIcon.Error, MessageBoxDefaultButton.Button1); return(false); } creaturesDict.Clear(); mainForm.SetCurrentStatus("Searching for packet indexes in lines..."); Parallel.For(0, lines.Length, index => { if (lines[index].Contains("SMSG_UPDATE_OBJECT") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_UPDATE_OBJECT); } else if (lines[index].Contains("SMSG_AI_REACTION") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_AI_REACTION); } else if (lines[index].Contains("SMSG_SPELL_START") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_START); } else if (lines[index].Contains("SMSG_CHAT") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_CHAT); } else if (lines[index].Contains("SMSG_ON_MONSTER_MOVE") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_ON_MONSTER_MOVE); } else if (lines[index].Contains("SMSG_ATTACK_STOP") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_ATTACK_STOP); } }); mainForm.SetCurrentStatus("Parsing SMSG_UPDATE_OBJECT packets..."); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { if (value.Value == Packet.PacketTypes.SMSG_UPDATE_OBJECT) { Parallel.ForEach(UpdateObjectPacket.ParseObjectUpdatePacket(lines, value.Key, buildVersion).AsEnumerable(), packet => { lock (creaturesDict) { if (!creaturesDict.ContainsKey(packet.creatureGuid)) { creaturesDict.Add(packet.creatureGuid, new Creature(packet)); } else { creaturesDict[packet.creatureGuid].UpdateCreature(packet); } } }); } }); mainForm.SetCurrentStatus("Parsing SMSG_SPELL_START packets..."); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { if (value.Value == Packet.PacketTypes.SMSG_SPELL_START) { SpellStartPacket spellPacket = SpellStartPacket.ParseSpellStartPacket(lines, value.Key, buildVersion); if (spellPacket.spellId == 0) { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(spellPacket.casterGuid)) { if (!creaturesDict[spellPacket.casterGuid].castedSpells.ContainsKey(spellPacket.spellId)) { creaturesDict[spellPacket.casterGuid].castedSpells.Add(spellPacket.spellId, new Spell(spellPacket)); } else { creaturesDict[spellPacket.casterGuid].UpdateSpells(spellPacket); } } } } }); mainForm.SetCurrentStatus("Parsing SMSG_AI_REACTION packets..."); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { if (value.Value == Packet.PacketTypes.SMSG_AI_REACTION) { AIReactionPacket reactionPacket = AIReactionPacket.ParseAIReactionPacket(lines, value.Key, buildVersion); if (reactionPacket.creatureGuid == "") { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(reactionPacket.creatureGuid)) { if (creaturesDict[reactionPacket.creatureGuid].combatStartTime == TimeSpan.Zero || creaturesDict[reactionPacket.creatureGuid].combatStartTime < reactionPacket.packetSendTime) { creaturesDict[reactionPacket.creatureGuid].combatStartTime = reactionPacket.packetSendTime; } creaturesDict[reactionPacket.creatureGuid].UpdateCombatSpells(reactionPacket); } } } }); mainForm.SetCurrentStatus("Parsing SMSG_CHAT packets..."); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { if (value.Value == Packet.PacketTypes.SMSG_CHAT) { ChatPacket chatPacket = ChatPacket.ParseChatPacket(lines, value.Key, buildVersion); if (chatPacket.creatureGuid == "") { return; } lock (creaturesDict) { Parallel.ForEach(creaturesDict, creature => { if (creature.Value.entry == chatPacket.creatureEntry) { if (Math.Floor(creature.Value.combatStartTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) || Math.Floor(creature.Value.combatStartTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) + 1 || Math.Floor(creature.Value.combatStartTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) - 1) { if (creatureTextsDict.ContainsKey(chatPacket.creatureEntry)) { if (!IsCreatureHasAggroText(chatPacket.creatureEntry)) { lock (creatureTextsDict) { creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, true)); } } } else { lock (creatureTextsDict) { creatureTextsDict.Add(chatPacket.creatureEntry, new List <CreatureText>()); creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, true)); } } } if (Math.Floor(creature.Value.deathTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) || Math.Floor(creature.Value.deathTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) + 1 || Math.Floor(creature.Value.deathTime.TotalSeconds) == Math.Floor(chatPacket.packetSendTime.TotalSeconds) - 1) { if (creatureTextsDict.ContainsKey(chatPacket.creatureEntry)) { if (!IsCreatureHasDeathText(chatPacket.creatureEntry)) { lock (creatureTextsDict) { creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, false, true)); } } } else { lock (creatureTextsDict) { creatureTextsDict.Add(chatPacket.creatureEntry, new List <CreatureText>()); creatureTextsDict[chatPacket.creatureEntry].Add(new CreatureText(chatPacket, false, true)); } } } } }); } } }); mainForm.SetCurrentStatus("Parsing SMSG_ON_MONSTER_MOVE and SMSG_ATTACK_STOP packets..."); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { switch (value.Value) { case Packet.PacketTypes.SMSG_ON_MONSTER_MOVE: { MonsterMovePacket movePacket = MonsterMovePacket.ParseMovementPacket(lines, value.Key, buildVersion); if (movePacket.creatureGuid == "") { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(movePacket.creatureGuid)) { creaturesDict[movePacket.creatureGuid].UpdateSpellsByMovementPacket(movePacket); } } break; } case Packet.PacketTypes.SMSG_ATTACK_STOP: { AttackStopPacket attackStopPacket = AttackStopPacket.ParseAttackStopkPacket(lines, value.Key, buildVersion); if (attackStopPacket.creatureGuid == "") { return; } lock (creaturesDict) { if (creaturesDict.ContainsKey(attackStopPacket.creatureGuid)) { creaturesDict[attackStopPacket.creatureGuid].UpdateSpellsByAttackStopPacket(attackStopPacket); if (attackStopPacket.nowDead) { creaturesDict[attackStopPacket.creatureGuid].deathTime = attackStopPacket.packetSendTime; } } } break; } } }); Parallel.ForEach(creaturesDict, creature => { creature.Value.RemoveNonCombatCastTimes(); }); Parallel.ForEach(creaturesDict, creature => { creature.Value.CreateCombatCastTimings(); }); Parallel.ForEach(creaturesDict, creature => { creature.Value.CreateDeathSpells(); }); mainForm.SetCurrentStatus(""); return(true); }
public static void ParseSpellDestinations(string fileName, string spellId) { var lines = File.ReadAllLines(fileName); string outputLine = ""; Dictionary <long, Packet.PacketTypes> packetIndexes = new Dictionary <long, Packet.PacketTypes>(); List <Position> allDestPositions = new List <Position>(); List <Position> uniqDestPositions = new List <Position>(); BuildVersions buildVersion = LineGetters.GetBuildVersion(lines); if (buildVersion == BuildVersions.BUILD_UNKNOWN) { MessageBox.Show(fileName + " has non-supported build.", "File Error", MessageBoxButtons.OK, MessageBoxIcon.Error, MessageBoxDefaultButton.Button1); return; } Parallel.For(0, lines.Length, index => { if (lines[index].Contains("SMSG_SPELL_START") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_START); } else if (lines[index].Contains("SMSG_SPELL_GO") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_GO); } }); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { if (value.Value == Packet.PacketTypes.SMSG_SPELL_START || value.Value == Packet.PacketTypes.SMSG_SPELL_GO) { SpellStartPacket spellPacket = SpellStartPacket.ParseSpellStartPacket(lines, value.Key, buildVersion); if (spellPacket.spellId == 0 || spellPacket.spellId != Convert.ToUInt32(spellId)) { return; } if (spellPacket.spellDestination.IsValid()) { lock (allDestPositions) allDestPositions.Add(spellPacket.spellDestination); if (!uniqDestPositions.Contains(spellPacket.spellDestination)) { lock (uniqDestPositions) uniqDestPositions.Add(spellPacket.spellDestination); } } } }); outputLine += "Spell destinations for spell " + spellId + "\n\n"; outputLine += "All positions count " + allDestPositions.Count + "\n"; foreach (Position pos in allDestPositions) { outputLine += "{ " + pos.x.ToString().Replace(",", ".") + "f, " + pos.y.ToString().Replace(",", ".") + "f, " + pos.z.ToString().Replace(",", ".") + "f },\n"; } outputLine += "Unique positions count " + allDestPositions.Count + "\n"; foreach (Position pos in uniqDestPositions) { outputLine += "{ " + pos.x.ToString().Replace(",", ".") + "f, " + pos.y.ToString().Replace(",", ".") + "f, " + pos.z.ToString().Replace(",", ".") + "f },\n"; } Clipboard.SetText(outputLine); MessageBox.Show("Spell destinations has been successfully parsed and copied on your clipboard!"); }
public static string ParsePlayerCastedSpells(string fileName, string playerGuid) { if (!DBC.DBC.IsLoaded()) { DBC.DBC.Load(); } var lines = File.ReadAllLines(fileName); string outputLine = ""; Dictionary <long, Packet.PacketTypes> packetIndexes = new Dictionary <long, Packet.PacketTypes>(); List <SpellStartPacket> spellsList = new List <SpellStartPacket>(); Dictionary <uint, uint> spellsCastedCount = new Dictionary <uint, uint>(); BuildVersions buildVersion = LineGetters.GetBuildVersion(lines); if (buildVersion == BuildVersions.BUILD_UNKNOWN) { MessageBox.Show(fileName + " has non-supported build.", "File Error", MessageBoxButtons.OK, MessageBoxIcon.Error, MessageBoxDefaultButton.Button1); return(""); } Parallel.For(0, lines.Length, index => { if (lines[index].Contains("SMSG_SPELL_START") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_START); } else if (lines[index].Contains("SMSG_SPELL_GO") && !packetIndexes.ContainsKey(index)) { lock (packetIndexes) packetIndexes.Add(index, Packet.PacketTypes.SMSG_SPELL_GO); } }); Parallel.ForEach(packetIndexes.AsEnumerable(), value => { if (value.Value == Packet.PacketTypes.SMSG_SPELL_START || value.Value == Packet.PacketTypes.SMSG_SPELL_GO) { SpellStartPacket spellPacket = SpellStartPacket.ParseSpellStartPacket(lines, value.Key, buildVersion, true); if (spellPacket.spellId == 0 || spellPacket.casterGuid != playerGuid) { return; } lock (spellsList) { int spellIndex = spellsList.FindIndex(x => x.spellId == spellPacket.spellId); if (spellIndex == -1) { spellsList.Add(spellPacket); spellsCastedCount.Add(spellPacket.spellId, 1); } else { if (spellsList[spellIndex].spellCastStartTime > spellPacket.spellCastStartTime) { spellsList.RemoveAt(spellIndex); spellsList.Add(spellPacket); } spellsCastedCount[spellPacket.spellId] += 1; } } } }); spellsList = spellsList.OrderBy(x => x.spellCastStartTime).ToList(); outputLine += "Spells casted by player with guid \"" + playerGuid + "\"" + "\r\n"; foreach (SpellStartPacket spell in spellsList) { outputLine += "Spell Id: " + spell.spellId + " (" + Spell.GetSpellName(spell.spellId) + "), Cast Time: " + spell.spellCastStartTime.ToFormattedStringWithMilliseconds() + ", Casted times: " + spellsCastedCount[spell.spellId] + "\r\n"; } return(outputLine); }