| Index: core/src/fxcodec/jbig2/JBig2_GsidProc.cpp
|
| diff --git a/core/src/fxcodec/jbig2/JBig2_GsidProc.cpp b/core/src/fxcodec/jbig2/JBig2_GsidProc.cpp
|
| index d89bb8f24940afc6c8dba0a197d3762e359c59c8..5f423c4b04b3f1fc8f8543d8f24061bf6734e7f0 100644
|
| --- a/core/src/fxcodec/jbig2/JBig2_GsidProc.cpp
|
| +++ b/core/src/fxcodec/jbig2/JBig2_GsidProc.cpp
|
| @@ -11,6 +11,7 @@
|
| #include "JBig2_BitStream.h"
|
| #include "JBig2_GrdProc.h"
|
| #include "JBig2_Image.h"
|
| +#include "JBig2_List.h"
|
|
|
| FX_DWORD* CJBig2_GSIDProc::decode_Arith(CJBig2_ArithDecoder* pArithDecoder,
|
| JBig2ArithCtx* gbContext,
|
| @@ -38,47 +39,32 @@ FX_DWORD* CJBig2_GSIDProc::decode_Arith(CJBig2_ArithDecoder* pArithDecoder,
|
| pGRD->GBAT[7] = -2;
|
| }
|
|
|
| - nonstd::unique_ptr<CJBig2_Image*, FxFreeDeleter> GSPLANES(
|
| - FX_Alloc(CJBig2_Image*, GSBPP));
|
| - JBIG2_memset(GSPLANES.get(), 0, sizeof(CJBig2_Image*) * GSBPP);
|
| - FXCODEC_STATUS status = pGRD->Start_decode_Arith(
|
| - &GSPLANES.get()[GSBPP - 1], pArithDecoder, gbContext, nullptr);
|
| - while (status == FXCODEC_STATUS_DECODE_TOBECONTINUE) {
|
| - pGRD->Continue_decode(pPause);
|
| - }
|
| - if (!GSPLANES.get()[GSBPP - 1])
|
| - return nullptr;
|
| -
|
| - int32_t J = GSBPP - 2;
|
| - while (J >= 0) {
|
| - FXCODEC_STATUS status = pGRD->Start_decode_Arith(
|
| - &GSPLANES.get()[J], pArithDecoder, gbContext, nullptr);
|
| - while (status == FXCODEC_STATUS_DECODE_TOBECONTINUE) {
|
| + CJBig2_List<CJBig2_Image> GSPLANES(GSBPP);
|
| + for (int32_t i = GSBPP - 1; i >= 0; --i) {
|
| + CJBig2_Image* pImage = nullptr;
|
| + FXCODEC_STATUS status =
|
| + pGRD->Start_decode_Arith(&pImage, pArithDecoder, gbContext, nullptr);
|
| + while (status == FXCODEC_STATUS_DECODE_TOBECONTINUE)
|
| pGRD->Continue_decode(pPause);
|
| - }
|
| - if (!GSPLANES.get()[J]) {
|
| - for (int32_t K = GSBPP - 1; K > J; --K) {
|
| - delete GSPLANES.get()[K];
|
| - return nullptr;
|
| - }
|
| - }
|
| - GSPLANES.get()[J]->composeFrom(0, 0, GSPLANES.get()[J + 1],
|
| - JBIG2_COMPOSE_XOR);
|
| - J = J - 1;
|
| +
|
| + if (!pImage)
|
| + return nullptr;
|
| +
|
| + GSPLANES.set(i, pImage);
|
| +
|
| + if (i < GSBPP - 1)
|
| + pImage->composeFrom(0, 0, GSPLANES.get(i + 1), JBIG2_COMPOSE_XOR);
|
| }
|
| nonstd::unique_ptr<FX_DWORD, FxFreeDeleter> GSVALS(
|
| FX_Alloc2D(FX_DWORD, GSW, GSH));
|
| JBIG2_memset(GSVALS.get(), 0, sizeof(FX_DWORD) * GSW * GSH);
|
| for (FX_DWORD y = 0; y < GSH; ++y) {
|
| for (FX_DWORD x = 0; x < GSW; ++x) {
|
| - for (J = 0; J < GSBPP; ++J) {
|
| - GSVALS.get()[y * GSW + x] |= GSPLANES.get()[J]->getPixel(x, y) << J;
|
| + for (int32_t i = 0; i < GSBPP; ++i) {
|
| + GSVALS.get()[y * GSW + x] |= GSPLANES.get(i)->getPixel(x, y) << i;
|
| }
|
| }
|
| }
|
| - for (J = 0; J < GSBPP; ++J) {
|
| - delete GSPLANES.get()[J];
|
| - }
|
| return GSVALS.release();
|
| }
|
|
|
|
|