Coverage Report

Created: 2022-05-03 06:27

/src/fuzz/animation_fuzzer.c
Line
Count
Source (jump to first uncovered line)
1
// Copyright 2020 Google LLC
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
//      http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
15
#include <stdint.h>
16
#include <gdk-pixbuf/gdk-pixbuf.h>
17
18
#include "fuzzer_temp_file.h"
19
20
9.80k
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
21
9.80k
    if (size < 1) {
22
0
        return 0;
23
0
    }
24
9.80k
    GError *error = NULL;
25
9.80k
    GdkPixbuf *pixbuf;
26
9.80k
    GdkPixbufAnimation *anim;
27
28
9.80k
    char *tmpfile = fuzzer_get_tmpfile(data, size);
29
9.80k
    anim = gdk_pixbuf_animation_new_from_file(tmpfile, &error);
30
9.80k
    if (error != NULL) {
31
9.80k
        g_clear_error(&error);
32
9.80k
        fuzzer_release_tmpfile(tmpfile);
33
9.80k
        return 0;
34
9.80k
    }
35
36
0
    char *buf = (char *) calloc(size + 1, sizeof(char));
37
0
    memcpy(buf, data, size);
38
0
    buf[size] = '\0';
39
40
0
    pixbuf = gdk_pixbuf_animation_get_static_image(anim);
41
0
    if (pixbuf != NULL) {
42
0
        unsigned int rot_amount = ((unsigned int) data[0]) % 4;
43
0
        pixbuf = gdk_pixbuf_rotate_simple(pixbuf, rot_amount * 90);
44
0
        gdk_pixbuf_set_option(pixbuf, buf, buf);
45
0
        gdk_pixbuf_get_pixels(pixbuf);
46
0
        gdk_pixbuf_get_width(pixbuf);
47
0
        gdk_pixbuf_get_height(pixbuf);
48
0
        g_object_unref(pixbuf);
49
0
    }
50
51
0
    free(buf);
52
0
    g_object_unref(anim);
53
0
    fuzzer_release_tmpfile(tmpfile);
54
0
    return 0;
55
9.80k
}