Mercurial > hg > dmlib
diff tools/gfxconv.c @ 1537:776aa43b2c57
Tiny improvement in MC->FLI upconversion.
author | Matti Hamalainen <ccr@tnsp.org> |
---|---|
date | Sat, 12 May 2018 04:46:08 +0300 |
parents | 74febc66d90d |
children | 416d7b3ba3b2 |
line wrap: on
line diff
--- a/tools/gfxconv.c Sat May 12 04:12:46 2018 +0300 +++ b/tools/gfxconv.c Sat May 12 04:46:08 2018 +0300 @@ -1051,16 +1051,35 @@ if ((dst->type & D64_FMT_FLI) && (src->type & D64_FMT_FLI) == 0) { dmMsg(1, "Upconverting multicolor to FLI.\n"); - for (int i = 0; i < src->nbanks; i++) + for (int i = 0; i < dst->nbanks; i++) { memcpy(dst->color[i], src->color[0], dst->screenSize); memcpy(dst->screen[i], src->screen[0], dst->screenSize); + memcpy(dst->bitmap[i], src->bitmap[0], dst->bitmapSize); + memcpy(dst->charmem[i], src->charmem[0], dst->charmemSize); } - for (int i = 0; i < dst->nbanks; i++) + for (int i = 0; i < D64_MAX_ENCDEC_OPS; i++) { - memcpy(dst->bitmap[i], src->bitmap[i], dst->bitmapSize); - memcpy(dst->charmem[i], src->charmem[i], dst->charmemSize); + const DMC64EncDecOp *op = &fmt->encdecOps[i]; + size_t size; + + // Check for last operator + if (op->type == DT_LAST) + break; + + // Check size + if (!dmC64GetOpSize(op, fmt, &size)) + return DMERR_INVALID_DATA; + + // Perform operation + switch (op->type) + { + case DT_EXTRA_DATA: + dst->extraData[op->bank] = dmMalloc0(size); + dst->extraDataSizes[op->bank] = size; + break; + } } } }