| * Copyright 2018 Google Inc. |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| #include "include/core/SkCanvas.h" |
| #include "include/core/SkPaint.h" |
| #include "include/core/SkPath.h" |
| #include "include/core/SkSurface.h" |
| #include "src/core/SkReadBuffer.h" |
| void FuzzPathDeserialize(SkReadBuffer& buf) { |
| auto s = SkSurface::MakeRasterN32Premul(128, 128); |
| // May return nullptr in memory-constrained fuzzing environments |
| s->getCanvas()->drawPath(path, SkPaint()); |
| #if defined(IS_FUZZING_WITH_LIBFUZZER) |
| extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) { |
| memcpy(&packed, data, 4); |
| unsigned version = packed & 0xFF; |
| // Chrome only will produce version 4, so guide the fuzzer to |
| // only focus on those branches. |
| SkReadBuffer buf(data, size); |
| FuzzPathDeserialize(buf); |