diff options
author | Wei Li <weili@chromium.org> | 2016-01-08 14:26:18 -0800 |
---|---|---|
committer | Wei Li <weili@chromium.org> | 2016-01-08 14:26:18 -0800 |
commit | 149f1db8bba85bdf2b40d330c38f2478695ca0d5 (patch) | |
tree | 1156a67f35ea8ac7e7077222fcc02b92471b23a7 /core/include | |
parent | e6bd31873c3dba3f79c5ebbbefed636948629cc9 (diff) | |
download | pdfium-149f1db8bba85bdf2b40d330c38f2478695ca0d5.tar.xz |
Fix infinite loop caused by parsing same indirect objects
BUG=pdfium:343
R=thestig@chromium.org
Review URL: https://codereview.chromium.org/1569343002 .
Diffstat (limited to 'core/include')
-rw-r--r-- | core/include/fpdfapi/fpdf_parser.h | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/core/include/fpdfapi/fpdf_parser.h b/core/include/fpdfapi/fpdf_parser.h index 756850932e..e1901ebdce 100644 --- a/core/include/fpdfapi/fpdf_parser.h +++ b/core/include/fpdfapi/fpdf_parser.h @@ -9,6 +9,7 @@ #include <map> #include <memory> +#include <set> #include "core/include/fpdfapi/fpdf_objects.h" #include "core/include/fxcrt/fx_system.h" @@ -536,6 +537,9 @@ class CPDF_Parser { // streams in |m_ObjectStreamMap| are valid. std::map<CPDF_StreamAcc*, StreamObjectCache> m_ObjCache; + // All indirect object numbers that are being parsed. + std::set<FX_DWORD> m_ParsingObjNums; + friend class CPDF_Creator; friend class CPDF_DataAvail; }; |