fix WX12-047 WX12-048

Bugs:
    * Do not solve when turn end even if attacked
    * Keep `attackCount` when turn end

  Reason:
    * `fieldData.attackCount++` cause `NaN` (`undefined` + 1)
    * Save turn limited `attackCount` on `fieldData`

  Fix:
    * Take care of `attackCount++`
    * Use `fieldTurnData` instead of `fieldData`
This commit is contained in:
WEBXOSS 2017-02-09 21:31:38 +08:00
parent 7f7c027fc0
commit bc10f92e0b
3 changed files with 10 additions and 5 deletions

View file

@ -101,6 +101,7 @@ function Card (game,player,zone,pid,side) {
this.charm = null; // 魅饰卡
this._data = null; // 私有的数据储存,约定: 只能在 CardInfo.js 自身的代码里访问
this.fieldData = {}; // 离场即清空的数据
this.fieldTurnData = {}; // 离场或回合结束即清空的数据
// 时点
this.onMove = new Timming(game);
@ -449,7 +450,7 @@ Card.prototype.canAttack = function () {
// <バインド・ウェポンズ>
if (this.type === 'SIGNI') {
var attackCount = this.fieldData.attackCount || 0;
var attackCount = this.fieldTurnData.attackCount || 0;
if (attackCount >= this.player.signiAttackCountLimit) return false;
} else {
var lrigAttackCount = this.game.getData(this.player,'lrigAttackCount') || 0;
@ -759,6 +760,7 @@ Card.prototype.moveTo = function (zone,arg) {
leaveFieldEvent = moveEvent;
card.frozen = false;
card.fieldData = {};
card.fieldTurnData = {};
charm = card.charm;
card.charm = null;
removeFromArr(card,card.player.signis);
@ -1019,8 +1021,8 @@ Card.prototype.attackAsyn = function () {
}
// <バインド・ウェポンズ>, <白羅星 フルムーン>
if (this.type === 'SIGNI') {
var attackCount = this.fieldData.attackCount || 0;
this.fieldData.attackCount++;
var attackCount = this.fieldTurnData.attackCount || 0;
this.fieldTurnData.attackCount = ++attackCount;
var signiAttackCount = this.game.getData(this.player,'signiAttackCount') || 0;
this.game.setData(this.player,'signiAttackCount',++signiAttackCount);
} else {

View file

@ -98877,7 +98877,7 @@ var CardInfo = {
source: this,
description: '1629-const-1',
condition: function () {
return this.fieldData.attackCount > 0;
return this.fieldTurnData.attackCount > 0;
},
actionAsyn: function () {
return this.player.discardAsyn(1);
@ -98952,7 +98952,7 @@ var CardInfo = {
source: this,
description: '1630-const-1',
condition: function () {
return this.fieldData.attackCount > 0;
return this.fieldTurnData.attackCount > 0;
},
actionAsyn: function () {
return this.player.discardAsyn(1);

View file

@ -333,6 +333,9 @@ Phase.prototype.endPhase = function () {
Phase.prototype.wixoss = function () {
this.additionalTurn = !!this.game.getData(this.player,'additionalTurn');
this.game.clearData();
this.game.cards.forEach(function (card) {
card.fieldTurnData = {}
});
this.status = '';
this.player.usedActionEffects.length = 0;
this.player.opponent.usedActionEffects.length = 0;