aboutsummaryrefslogtreecommitdiff
path: root/projects/tidy-html5/tidy_xml_fuzzer.c
blob: c40551193952d93046e5f3d3dedd13c43143ad93 (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
60
61
62
63
64
65
66
/*
 * Copyright 2021 Google LLC
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
#include <sys/types.h>
#include <stdlib.h>
#include <stdio.h>
#include <stdint.h>
#include "tidy.h"
#include "tidybuffio.h"
#include "tidyenum.h"
#include "tidyplatform.h"

void TidyXml(char *fuzz_inp, TidyBuffer *toutput,
             TidyBuffer *terror) {
  TidyDoc tdoc = tidyCreate();
  tidyBufClear(toutput);
  tidyBufClear(terror);
  if (tidyOptSetBool(tdoc, TidyXmlOut, yes)) {
    tidySetCharEncoding(tdoc, "utf8");
    tidySetErrorBuffer(tdoc, terror);
    tidyOptSetInt(tdoc, TidyWrapLen, 0);
    tidyOptSetBool(tdoc, TidyXmlTags, yes);
    tidyOptSetBool(tdoc, TidyQuoteNbsp, no);
    tidyOptSetBool(tdoc, TidyNumEntities, yes);
    tidyOptSetBool(tdoc, TidyQuiet, yes);
    tidyOptSetBool(tdoc, TidyMark, no);
    tidyOptSetBool(tdoc, TidyShowWarnings, no);
    tidyParseString(tdoc, fuzz_inp);
    tidyCleanAndRepair(tdoc);
    tidyRunDiagnostics(tdoc);
    tidySaveBuffer(tdoc, toutput);
  }

  tidyRelease(tdoc);
}

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  char *fuzz_inp = malloc(size+1);
  memcpy(fuzz_inp, data, size);
  fuzz_inp[size] = '\0';

  TidyBuffer fuzz_toutput;
  TidyBuffer fuzz_terror;

  tidyBufInit(&fuzz_toutput);
  tidyBufInit(&fuzz_terror);

  TidyXml(fuzz_inp, &fuzz_toutput, &fuzz_terror);

  free(fuzz_inp);
  tidyBufFree(&fuzz_toutput);
  tidyBufFree(&fuzz_terror);
  return 0;
}