1
0
Fork 0

(svn r7711) -Fix (r7354): NewGRF Action 7, GRF check condition 10 didn't ignore unknown GRF IDs. Also separate GRF ID conditions

from parameter conditions to remove code duplication in GRF checking code.
release/0.6
peter1138 2007-01-01 01:40:56 +00:00
parent 71c89cf8ee
commit 3ba932e30f
1 changed files with 47 additions and 49 deletions

View File

@ -2351,65 +2351,63 @@ static void SkipIf(byte *buf, int len)
return; return;
} }
if (param == 0x88 && GetFileByGRFID(cond_val) == NULL) {
grfmsg(7, "GRFID 0x%08X unknown, skipping test", BSWAP32(cond_val));
return;
}
param_val = GetParamVal(param, &cond_val); param_val = GetParamVal(param, &cond_val);
grfmsg(7, "Test condtype %d, param 0x%08X, condval 0x%08X", condtype, param_val, cond_val); grfmsg(7, "Test condtype %d, param 0x%08X, condval 0x%08X", condtype, param_val, cond_val);
switch (condtype) {
case 0: result = !!(param_val & (1 << cond_val));
break;
case 1: result = !(param_val & (1 << cond_val));
break;
case 2: result = (param_val & mask) == cond_val;
break;
case 3: result = (param_val & mask) != cond_val;
break;
case 4: result = (param_val & mask) < cond_val;
break;
case 5: result = (param_val & mask) > cond_val;
break;
/* Tests 6 to 10 are only for param 0x88, GRFID checks */ if (param == 0x88) {
case 6: { /* Is GRFID active? */ /* GRF ID checks */
const GRFConfig *c = GetGRFConfig(cond_val);
if (c == NULL) return; const GRFConfig *c = GetGRFConfig(cond_val);
result = HASBIT(c->flags, GCF_ACTIVATED);
break; if (condtype != 10 && c == NULL) {
grfmsg(7, "GRFID 0x%08X unknown, skipping test", BSWAP32(cond_val));
return;
} }
case 7: { /* Is GRFID non-active? */ switch (condtype) {
const GRFConfig *c = GetGRFConfig(cond_val); /* Tests 6 to 10 are only for param 0x88, GRFID checks */
if (c == NULL) return; case 6: /* Is GRFID active? */
result = !HASBIT(c->flags, GCF_ACTIVATED); result = HASBIT(c->flags, GCF_ACTIVATED);
break; break;
}
case 8: { /* GRFID is not but will be active? */ case 7: /* Is GRFID non-active? */
const GRFConfig *c = GetGRFConfig(cond_val); result = !HASBIT(c->flags, GCF_ACTIVATED);
if (c == NULL) return; break;
result = !HASBIT(c->flags, GCF_ACTIVATED) && !HASBIT(c->flags, GCF_DISABLED);
break;
}
case 9: { /* GRFID is or will be active? */ case 8: /* GRFID is not but will be active? */
const GRFConfig *c = GetGRFConfig(cond_val); result = !HASBIT(c->flags, GCF_ACTIVATED) && !HASBIT(c->flags, GCF_DISABLED);
if (c == NULL) return; break;
result = !HASBIT(c->flags, GCF_NOT_FOUND) && !HASBIT(c->flags, GCF_DISABLED);
break;
}
case 10: { /* GRFID is not nor will be active */ case 9: /* GRFID is or will be active? */
const GRFConfig *c = GetGRFConfig(cond_val); result = !HASBIT(c->flags, GCF_NOT_FOUND) && !HASBIT(c->flags, GCF_DISABLED);
/* This is the only condtype that doesn't get ignored if the GRFID is not found */ break;
result = c == NULL || HASBIT(c->flags, GCF_DISABLED) || HASBIT(c->flags, GCF_NOT_FOUND);
break;
}
default: grfmsg(1, "Unsupported test %d. Ignoring", condtype); return; case 10: /* GRFID is not nor will be active */
/* This is the only condtype that doesn't get ignored if the GRFID is not found */
result = c == NULL || HASBIT(c->flags, GCF_DISABLED) || HASBIT(c->flags, GCF_NOT_FOUND);
break;
default: grfmsg(1, "Unsupported GRF test %d. Ignoring", condtype); return;
}
} else {
/* Parameter or variable tests */
switch (condtype) {
case 0: result = !!(param_val & (1 << cond_val));
break;
case 1: result = !(param_val & (1 << cond_val));
break;
case 2: result = (param_val & mask) == cond_val;
break;
case 3: result = (param_val & mask) != cond_val;
break;
case 4: result = (param_val & mask) < cond_val;
break;
case 5: result = (param_val & mask) > cond_val;
break;
default: grfmsg(1, "Unsupported test %d. Ignoring", condtype); return;
}
} }
if (!result) { if (!result) {