blob: 5728b0237f342b5e91064fc13d5c724224f978e1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
/*
* Copyright 2017 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkJpegPriv_DEFINED
#define SkJpegPriv_DEFINED
#include "include/codec/SkEncodedOrigin.h"
#include "include/core/SkStream.h"
#include "include/private/base/SkTArray.h"
#include <setjmp.h>
// stdio is needed for jpeglib
#include <stdio.h>
extern "C" {
#include "jpeglib.h" // NO_G3_REWRITE
#include "jerror.h" // NO_G3_REWRITE
}
/*
* Error handling struct
*/
struct skjpeg_error_mgr : jpeg_error_mgr {
class AutoPushJmpBuf {
public:
AutoPushJmpBuf(skjpeg_error_mgr* mgr) : fMgr(mgr) { fMgr->push(&fJmpBuf); }
~AutoPushJmpBuf() { fMgr->pop(&fJmpBuf); }
operator jmp_buf&() { return fJmpBuf; }
private:
skjpeg_error_mgr* const fMgr;
jmp_buf fJmpBuf;
};
void push(jmp_buf* j) {
SkASSERT(fStack[3] == nullptr); // if we assert here, the stack has overflowed
fStack[3] = fStack[2];
fStack[2] = fStack[1];
fStack[1] = fStack[0];
fStack[0] = j;
}
void pop(jmp_buf* j) {
SkASSERT(fStack[0] == j); // if we assert here, the pushes and pops were unbalanced
fStack[0] = fStack[1];
fStack[1] = fStack[2];
fStack[2] = fStack[3];
fStack[3] = nullptr;
}
jmp_buf* fStack[4] = {};
};
#endif
|