diff options
author | Vincent Sanders <vince@kyllikki.org> | 2015-04-15 22:03:34 +0100 |
---|---|---|
committer | Vincent Sanders <vince@kyllikki.org> | 2015-04-15 22:05:10 +0100 |
commit | 9679561eca26bf792764002465bc0548c5d694bf (patch) | |
tree | b3601c217252929686af291e5df5e731c44f6fdd /monkey/bitmap.c | |
parent | cc11912da1e2881803828330f85b0fe177b570b6 (diff) | |
download | netsurf-9679561eca26bf792764002465bc0548c5d694bf.tar.gz netsurf-9679561eca26bf792764002465bc0548c5d694bf.tar.bz2 |
Update monkey frontend to use bitmap operation table.
Diffstat (limited to 'monkey/bitmap.c')
-rw-r--r-- | monkey/bitmap.c | 44 |
1 files changed, 32 insertions, 12 deletions
diff --git a/monkey/bitmap.c b/monkey/bitmap.c index 79bab8cd5..16c98b594 100644 --- a/monkey/bitmap.c +++ b/monkey/bitmap.c @@ -18,9 +18,12 @@ #include <stdbool.h> #include <stdio.h> +#include <stdlib.h> #include "image/bitmap.h" +#include "monkey/bitmap.h" + struct bitmap { void *ptr; size_t rowstride; @@ -29,7 +32,7 @@ struct bitmap { unsigned int state; }; -void *bitmap_create(int width, int height, unsigned int state) +static void *bitmap_create(int width, int height, unsigned int state) { struct bitmap *ret = calloc(sizeof(*ret), 1); if (ret == NULL) @@ -49,14 +52,14 @@ void *bitmap_create(int width, int height, unsigned int state) return ret; } -void bitmap_destroy(void *bitmap) +static void bitmap_destroy(void *bitmap) { struct bitmap *bmap = bitmap; free(bmap->ptr); free(bmap); } -void bitmap_set_opaque(void *bitmap, bool opaque) +static void bitmap_set_opaque(void *bitmap, bool opaque) { struct bitmap *bmap = bitmap; @@ -66,56 +69,73 @@ void bitmap_set_opaque(void *bitmap, bool opaque) bmap->state &= ~(BITMAP_OPAQUE); } -bool bitmap_test_opaque(void *bitmap) +static bool bitmap_test_opaque(void *bitmap) { return false; } -bool bitmap_get_opaque(void *bitmap) +static bool bitmap_get_opaque(void *bitmap) { struct bitmap *bmap = bitmap; return (bmap->state & BITMAP_OPAQUE) == BITMAP_OPAQUE; } -unsigned char *bitmap_get_buffer(void *bitmap) +static unsigned char *bitmap_get_buffer(void *bitmap) { struct bitmap *bmap = bitmap; return (unsigned char *)(bmap->ptr); } -size_t bitmap_get_rowstride(void *bitmap) +static size_t bitmap_get_rowstride(void *bitmap) { struct bitmap *bmap = bitmap; return bmap->width * 4; } -size_t bitmap_get_bpp(void *bitmap) +static size_t bitmap_get_bpp(void *bitmap) { /* OMG?! */ return 4; } -bool bitmap_save(void *bitmap, const char *path, unsigned flags) +static bool bitmap_save(void *bitmap, const char *path, unsigned flags) { return true; } -void bitmap_modified(void *bitmap) +static void bitmap_modified(void *bitmap) { struct bitmap *bmap = bitmap; bmap->state |= BITMAP_MODIFIED; } -int bitmap_get_width(void *bitmap) +static int bitmap_get_width(void *bitmap) { struct bitmap *bmap = bitmap; return bmap->width; } -int bitmap_get_height(void *bitmap) +static int bitmap_get_height(void *bitmap) { struct bitmap *bmap = bitmap; return bmap->height; } + +static struct gui_bitmap_table bitmap_table = { + .create = bitmap_create, + .destroy = bitmap_destroy, + .set_opaque = bitmap_set_opaque, + .get_opaque = bitmap_get_opaque, + .test_opaque = bitmap_test_opaque, + .get_buffer = bitmap_get_buffer, + .get_rowstride = bitmap_get_rowstride, + .get_width = bitmap_get_width, + .get_height = bitmap_get_height, + .get_bpp = bitmap_get_bpp, + .save = bitmap_save, + .modified = bitmap_modified, +}; + +struct gui_bitmap_table *monkey_bitmap_table = &bitmap_table; |