@firestone-hs/replay-parser
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 8.2.9.
171 lines • 23.3 kB
JavaScript
import { Injectable } from '@angular/core';
import { GameTag } from '@firestone-hs/reference-data';
import { ChangeEntityHistoryItem } from '../models/history/change-entity-history-item';
import { FullEntityHistoryItem } from '../models/history/full-entity-history-item';
import { ShowEntityHistoryItem } from '../models/history/show-entity-history-item';
import { TagChangeHistoryItem } from '../models/history/tag-change-history-item';
import * as i0 from "@angular/core";
export class StateProcessorService {
constructor() {
this.USEFUL_TAGS = [
GameTag._333,
GameTag.ARMOR,
GameTag.ATK,
GameTag.ATTACHED,
GameTag.BACON_HERO_CAN_BE_DRAFTED,
GameTag.BOARD_VISUAL_STATE,
GameTag.CANT_BE_TARGETED_BY_HERO_POWERS,
GameTag.CANT_BE_TARGETED_BY_SPELLS,
GameTag.CARDTYPE,
GameTag.CHARGE,
GameTag.CLASS,
GameTag.CONTROLLER,
GameTag.COST,
GameTag.CREATOR,
GameTag.CURRENT_HEROPOWER_DAMAGE_BONUS,
GameTag.CURRENT_PLAYER,
GameTag.CURRENT_SPELLPOWER_BASE,
GameTag.DAMAGE,
GameTag.DEATHRATTLE,
GameTag.DIVINE_SHIELD,
GameTag.DURABILITY,
GameTag.EXHAUSTED,
GameTag.EXHAUSTED,
GameTag.FROZEN,
GameTag.GAME_MODE_BUTTON_SLOT,
GameTag.HEALTH,
GameTag.HEAVILY_ARMORED,
GameTag.HERO_ENTITY,
GameTag.HERO_POWER_DISABLED,
GameTag.HERO_POWER_DISABLED,
GameTag.HERO_POWER_DOUBLE,
GameTag.HIDDEN_CHOICE,
GameTag.HIDE_STATS,
GameTag.IMMUNE,
GameTag.INSPIRE,
GameTag.JUST_PLAYED,
GameTag.LIFESTEAL,
GameTag.MULLIGAN_STATE,
GameTag.NEXT_OPPONENT_PLAYER_ID,
GameTag.NUM_CARDS_PLAYED_THIS_TURN,
GameTag.NUM_RESOURCES_SPENT_THIS_GAME,
GameTag.OVERLOAD_LOCKED,
GameTag.OVERLOAD_OWED,
GameTag.PARENT_CARD,
GameTag.PLAYER_ID,
GameTag.PLAYER_LEADERBOARD_PLACE,
GameTag.PLAYER_TECH_LEVEL,
GameTag.PLAYSTATE,
GameTag.POISONOUS,
GameTag.PREMIUM,
GameTag.PREMIUM,
GameTag.QUEST_PROGRESS_TOTAL,
GameTag.QUEST_PROGRESS,
GameTag.QUEST,
GameTag.REBORN,
GameTag.RECEIVES_DOUBLE_SPELLDAMAGE_BONUS,
GameTag.RESOURCES_USED,
GameTag.RESOURCES,
GameTag.SECRET,
GameTag.SILENCED,
GameTag.SPELLPOWER_DOUBLE,
GameTag.STEALTH,
GameTag.STEP,
GameTag.TAG_SCRIPT_DATA_NUM_1,
GameTag.TAG_SCRIPT_DATA_NUM_2,
GameTag.TAUNT,
GameTag.TECH_LEVEL_MANA_GEM,
GameTag.TECH_LEVEL,
GameTag.TRIGGER_VISUAL,
GameTag.TURN,
GameTag.WINDFURY,
GameTag.ZONE_POSITION,
GameTag.ZONE,
];
}
applyHistoryUntilEnd(previousStateEntities, history, previousProcessedItem) {
const startIndex = history.indexOf(previousProcessedItem);
const futureHistory = history.slice(startIndex);
let newStateEntities = previousStateEntities;
// // console.log('applying history until now', startIndex, futureHistory, history);
for (const historyItem of futureHistory) {
newStateEntities = this.applyHistoryItem(newStateEntities, historyItem);
}
// // console.log('after history applied 150', newStateEntities.get(150) && newStateEntities.get(150).tags.toJS());
return newStateEntities;
}
applyHistoryItem(entities, item) {
if (item instanceof TagChangeHistoryItem) {
return this.updateWithTagChange(item, entities);
}
else if (item instanceof ShowEntityHistoryItem || item instanceof FullEntityHistoryItem) {
return this.updateWithEntity(item, entities);
}
else if (item instanceof ChangeEntityHistoryItem) {
return this.updateWithChangeEntity(item, entities);
}
return entities;
// TODO: options, choices, chosen entities
}
updateWithEntity(historyItem, entities) {
if (historyItem.entityDefintion.id === 35) {
// console.log('applying history item', historyItem, historyItem.entityDefintion.tags?.toJS());
}
if (!entities.get(historyItem.entityDefintion.id)) {
console.warn('[state-processor] could not update entity', historyItem.entityDefintion.id);
return entities;
}
// if (historyItem.entityDefintion.id === 73 || historyItem.entityDefintion.id === 74) {
// // console.log('enriching state', historyItem);
// }
const entity = entities.get(historyItem.entityDefintion.id).update(historyItem.entityDefintion);
// if (entity.id === 150) {
// // console.log(
// 'updating with 150',
// entity,
// entity.tags.toJS(),
// entities
// .set(entity.id, entity)
// .get(150)
// .tags.toJS(),
// );
// }
return entities.set(entity.id, entity);
}
updateWithChangeEntity(historyItem, entities) {
if (!entities.get(historyItem.entityDefintion.id)) {
console.warn('[state-processor] could not update entity', historyItem.entityDefintion.id);
return entities;
}
const entity = entities.get(historyItem.entityDefintion.id).update(historyItem.entityDefintion);
return entities.set(entity.id, entity);
}
updateWithTagChange(historyItem, entities) {
// Only a limited number of tags are useful for replay reconstitution. If the tag isn't
// one of them, we simply ignore it. Thanks to this, we will have less differences
// between our entities, which will improve the memory footprint and performances
if (this.USEFUL_TAGS.indexOf(historyItem.tag.tag) === -1) {
return entities;
}
// No default creation - if the entity is not registered yet, it's a bug
// It sometimes happens that the XML itself doesn't have the right entity
// so we safeguard here
if (!entities.get(historyItem.tag.entity)) {
console.warn('[state-processor] could not update entity', historyItem.tag.entity);
return entities;
}
const entity = entities
.get(historyItem.tag.entity)
.updateTag(historyItem.tag.tag, historyItem.tag.value);
return entities.set(entity.id, entity);
}
}
StateProcessorService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.1", ngImport: i0, type: StateProcessorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
StateProcessorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.1", ngImport: i0, type: StateProcessorService, providedIn: 'root' });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.1", ngImport: i0, type: StateProcessorService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root',
}]
}], ctorParameters: function () { return []; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state-processor.service.js","sourceRoot":"","sources":["../../../../../projects/replay-parser/src/lib/services/state-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { GameTag } from '@firestone-hs/reference-data';\r\nimport { Map } from 'immutable';\r\nimport { Entity } from '../models/game/entity';\r\nimport { ChangeEntityHistoryItem } from '../models/history/change-entity-history-item';\r\nimport { FullEntityHistoryItem } from '../models/history/full-entity-history-item';\r\nimport { HistoryItem } from '../models/history/history-item';\r\nimport { ShowEntityHistoryItem } from '../models/history/show-entity-history-item';\r\nimport { TagChangeHistoryItem } from '../models/history/tag-change-history-item';\r\n\r\n@Injectable({\r\n\tprovidedIn: 'root',\r\n})\r\nexport class StateProcessorService {\r\n\tconstructor() {}\r\n\r\n\tprivate readonly USEFUL_TAGS: readonly GameTag[] = [\r\n\t\tGameTag._333,\r\n\t\tGameTag.ARMOR,\r\n\t\tGameTag.ATK,\r\n\t\tGameTag.ATTACHED,\r\n\t\tGameTag.BACON_HERO_CAN_BE_DRAFTED,\r\n\t\tGameTag.BOARD_VISUAL_STATE,\r\n\t\tGameTag.CANT_BE_TARGETED_BY_HERO_POWERS,\r\n\t\tGameTag.CANT_BE_TARGETED_BY_SPELLS,\r\n\t\tGameTag.CARDTYPE,\r\n\t\tGameTag.CHARGE,\r\n\t\tGameTag.CLASS,\r\n\t\tGameTag.CONTROLLER,\r\n\t\tGameTag.COST,\r\n\t\tGameTag.CREATOR,\r\n\t\tGameTag.CURRENT_HEROPOWER_DAMAGE_BONUS,\r\n\t\tGameTag.CURRENT_PLAYER,\r\n\t\tGameTag.CURRENT_SPELLPOWER_BASE,\r\n\t\tGameTag.DAMAGE,\r\n\t\tGameTag.DEATHRATTLE,\r\n\t\tGameTag.DIVINE_SHIELD,\r\n\t\tGameTag.DURABILITY,\r\n\t\tGameTag.EXHAUSTED,\r\n\t\tGameTag.EXHAUSTED,\r\n\t\tGameTag.FROZEN,\r\n\t\tGameTag.GAME_MODE_BUTTON_SLOT, // Used to know what button is active in a specific slot\r\n\t\tGameTag.HEALTH,\r\n\t\tGameTag.HEAVILY_ARMORED,\r\n\t\tGameTag.HERO_ENTITY,\r\n\t\tGameTag.HERO_POWER_DISABLED,\r\n\t\tGameTag.HERO_POWER_DISABLED,\r\n\t\tGameTag.HERO_POWER_DOUBLE,\r\n\t\tGameTag.HIDDEN_CHOICE,\r\n\t\tGameTag.HIDE_STATS,\r\n\t\tGameTag.IMMUNE,\r\n\t\tGameTag.INSPIRE,\r\n\t\tGameTag.JUST_PLAYED,\r\n\t\tGameTag.LIFESTEAL,\r\n\t\tGameTag.MULLIGAN_STATE,\r\n\t\tGameTag.NEXT_OPPONENT_PLAYER_ID,\r\n\t\tGameTag.NUM_CARDS_PLAYED_THIS_TURN,\r\n\t\tGameTag.NUM_RESOURCES_SPENT_THIS_GAME,\r\n\t\tGameTag.OVERLOAD_LOCKED,\r\n\t\tGameTag.OVERLOAD_OWED,\r\n\t\tGameTag.PARENT_CARD,\r\n\t\tGameTag.PLAYER_ID,\r\n\t\tGameTag.PLAYER_LEADERBOARD_PLACE,\r\n\t\tGameTag.PLAYER_TECH_LEVEL,\r\n\t\tGameTag.PLAYSTATE,\r\n\t\tGameTag.POISONOUS,\r\n\t\tGameTag.PREMIUM,\r\n\t\tGameTag.PREMIUM,\r\n\t\tGameTag.QUEST_PROGRESS_TOTAL,\r\n\t\tGameTag.QUEST_PROGRESS,\r\n\t\tGameTag.QUEST,\r\n\t\tGameTag.REBORN,\r\n\t\tGameTag.RECEIVES_DOUBLE_SPELLDAMAGE_BONUS,\r\n\t\tGameTag.RESOURCES_USED,\r\n\t\tGameTag.RESOURCES,\r\n\t\tGameTag.SECRET,\r\n\t\tGameTag.SILENCED,\r\n\t\tGameTag.SPELLPOWER_DOUBLE,\r\n\t\tGameTag.STEALTH,\r\n\t\tGameTag.STEP,\r\n\t\tGameTag.TAG_SCRIPT_DATA_NUM_1,\r\n\t\tGameTag.TAG_SCRIPT_DATA_NUM_2,\r\n\t\tGameTag.TAUNT,\r\n\t\tGameTag.TECH_LEVEL_MANA_GEM,\r\n\t\tGameTag.TECH_LEVEL,\r\n\t\tGameTag.TRIGGER_VISUAL,\r\n\t\tGameTag.TURN,\r\n\t\tGameTag.WINDFURY,\r\n\t\tGameTag.ZONE_POSITION,\r\n\t\tGameTag.ZONE,\r\n\t];\r\n\r\n\tpublic applyHistoryUntilEnd(\r\n\t\tpreviousStateEntities: Map<number, Entity>,\r\n\t\thistory: readonly HistoryItem[],\r\n\t\tpreviousProcessedItem: HistoryItem,\r\n\t): Map<number, Entity> {\r\n\t\tconst startIndex = history.indexOf(previousProcessedItem);\r\n\t\tconst futureHistory = history.slice(startIndex);\r\n\t\tlet newStateEntities = previousStateEntities;\r\n\t\t// // console.log('applying history until now', startIndex, futureHistory, history);\r\n\t\tfor (const historyItem of futureHistory) {\r\n\t\t\tnewStateEntities = this.applyHistoryItem(newStateEntities, historyItem);\r\n\t\t}\r\n\t\t// // console.log('after history applied 150', newStateEntities.get(150) && newStateEntities.get(150).tags.toJS());\r\n\t\treturn newStateEntities;\r\n\t}\r\n\r\n\tpublic applyHistoryItem(entities: Map<number, Entity>, item: HistoryItem): Map<number, Entity> {\r\n\t\tif (item instanceof TagChangeHistoryItem) {\r\n\t\t\treturn this.updateWithTagChange(item, entities);\r\n\t\t} else if (item instanceof ShowEntityHistoryItem || item instanceof FullEntityHistoryItem) {\r\n\t\t\treturn this.updateWithEntity(item, entities);\r\n\t\t} else if (item instanceof ChangeEntityHistoryItem) {\r\n\t\t\treturn this.updateWithChangeEntity(item, entities);\r\n\t\t}\r\n\t\treturn entities;\r\n\t\t// TODO: options, choices, chosen entities\r\n\t}\r\n\r\n\tprivate updateWithEntity(\r\n\t\thistoryItem: ShowEntityHistoryItem | FullEntityHistoryItem,\r\n\t\tentities: Map<number, Entity>,\r\n\t): Map<number, Entity> {\r\n\t\tif (historyItem.entityDefintion.id === 35) {\r\n\t\t\t// console.log('applying history item', historyItem, historyItem.entityDefintion.tags?.toJS());\r\n\t\t}\r\n\t\tif (!entities.get(historyItem.entityDefintion.id)) {\r\n\t\t\tconsole.warn('[state-processor] could not update entity', historyItem.entityDefintion.id);\r\n\t\t\treturn entities;\r\n\t\t}\r\n\r\n\t\t// if (historyItem.entityDefintion.id === 73 || historyItem.entityDefintion.id === 74) {\r\n\t\t// \t// console.log('enriching state', historyItem);\r\n\t\t// }\r\n\t\tconst entity: Entity = entities.get(historyItem.entityDefintion.id).update(historyItem.entityDefintion);\r\n\t\t// if (entity.id === 150) {\r\n\t\t// \t// console.log(\r\n\t\t// \t\t'updating with 150',\r\n\t\t// \t\tentity,\r\n\t\t// \t\tentity.tags.toJS(),\r\n\t\t// \t\tentities\r\n\t\t// \t\t\t.set(entity.id, entity)\r\n\t\t// \t\t\t.get(150)\r\n\t\t// \t\t\t.tags.toJS(),\r\n\t\t// \t);\r\n\t\t// }\r\n\t\treturn entities.set(entity.id, entity);\r\n\t}\r\n\r\n\tprivate updateWithChangeEntity(\r\n\t\thistoryItem: ChangeEntityHistoryItem,\r\n\t\tentities: Map<number, Entity>,\r\n\t): Map<number, Entity> {\r\n\t\tif (!entities.get(historyItem.entityDefintion.id)) {\r\n\t\t\tconsole.warn('[state-processor] could not update entity', historyItem.entityDefintion.id);\r\n\t\t\treturn entities;\r\n\t\t}\r\n\t\tconst entity: Entity = entities.get(historyItem.entityDefintion.id).update(historyItem.entityDefintion);\r\n\t\treturn entities.set(entity.id, entity);\r\n\t}\r\n\r\n\tprivate updateWithTagChange(historyItem: TagChangeHistoryItem, entities: Map<number, Entity>): Map<number, Entity> {\r\n\t\t// Only a limited number of tags are useful for replay reconstitution. If the tag isn't\r\n\t\t// one of them, we simply ignore it. Thanks to this, we will have less differences\r\n\t\t// between our entities, which will improve the memory footprint and performances\r\n\t\tif (this.USEFUL_TAGS.indexOf(historyItem.tag.tag) === -1) {\r\n\t\t\treturn entities;\r\n\t\t}\r\n\t\t// No default creation - if the entity is not registered yet, it's a bug\r\n\t\t// It sometimes happens that the XML itself doesn't have the right entity\r\n\t\t// so we safeguard here\r\n\t\tif (!entities.get(historyItem.tag.entity)) {\r\n\t\t\tconsole.warn('[state-processor] could not update entity', historyItem.tag.entity);\r\n\t\t\treturn entities;\r\n\t\t}\r\n\r\n\t\tconst entity: Entity = entities\r\n\t\t\t.get(historyItem.tag.entity)\r\n\t\t\t.updateTag(historyItem.tag.tag, historyItem.tag.value);\r\n\t\treturn entities.set(entity.id, entity);\r\n\t}\r\n}\r\n"]}