Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The PDFium Authors. All rights reserved. | 1 // Copyright 2016 The PDFium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include <memory> | 5 #include <memory> |
| 6 | 6 |
| 7 #include "core/fxcrt/include/fx_string.h" | 7 #include "xfa/fde/xml/cfx_saxreader.h" |
| 8 #include "xfa/fde/css/fde_css.h" | |
| 9 #include "xfa/fde/css/fde_csssyntax.h" | |
| 10 #include "xfa/fgas/crt/fgas_stream.h" | 8 #include "xfa/fgas/crt/fgas_stream.h" |
| 11 #include "xfa/fxfa/parser/xfa_utils.h" | 9 #include "xfa/fxfa/parser/xfa_utils.h" |
| 12 | 10 |
| 13 extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { | 11 extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { |
| 14 CFDE_CSSSyntaxParser parser; | |
| 15 | |
| 16 CFX_WideString input = CFX_WideString::FromUTF8( | 12 CFX_WideString input = CFX_WideString::FromUTF8( |
| 17 CFX_ByteStringC(data, static_cast<FX_STRSIZE>(size))); | 13 CFX_ByteStringC(data, static_cast<FX_STRSIZE>(size))); |
| 18 std::unique_ptr<IFX_Stream, ReleaseDeleter<IFX_Stream>> stream( | 14 std::unique_ptr<IFX_Stream, ReleaseDeleter<IFX_Stream>> stream( |
| 19 XFA_CreateWideTextRead(input)); | 15 XFA_CreateWideTextRead(input)); |
| 20 if (!stream) | 16 if (!stream) |
| 21 return 0; | 17 return 0; |
| 22 | 18 |
| 23 parser.Init(stream.get(), 1024); | 19 std::unique_ptr<IFX_FileRead, ReleaseDeleter<IFX_FileRead>> fileRead( |
| 20 FX_CreateFileRead(stream.get(), false)); | |
| 21 if (!fileRead) | |
| 22 return 0; | |
| 24 | 23 |
| 25 FDE_CSSSYNTAXSTATUS status = parser.DoSyntaxParse(); | 24 CFX_SAXReader reader; |
| 26 while (status != FDE_CSSSYNTAXSTATUS_Error && | 25 if (reader.StartParse(fileRead.get(), 0, -1, CFX_SaxParseMode_NotSkipSpace) < |
| 27 status != FDE_CSSSYNTAXSTATUS_EOS) | 26 0) { |
| 28 status = parser.DoSyntaxParse(); | 27 return 0; |
| 28 } | |
| 29 | |
| 30 while (1) { | |
|
dsinclair
2016/06/15 17:54:32
Will clusterfuzz time this out if it goes bonkers?
Oliver Chang
2016/06/15 22:43:44
Yeah, the libFuzzer driver also handles timeouts.
| |
| 31 int32_t ret = reader.ContinueParse(nullptr); | |
| 32 if (ret < 0 || ret > 99) | |
| 33 break; | |
| 34 } | |
| 29 | 35 |
| 30 return 0; | 36 return 0; |
| 31 } | 37 } |
| OLD | NEW |