Merge branch 'test-png16-load' into 'master'

Add test for loading 16 bit PNG images

See merge request cairo/cairo!241
This commit is contained in:
Uli Schlachter 2023-01-15 19:54:04 +00:00
commit b23ecf6322
7 changed files with 86 additions and 1 deletions

View file

@ -1266,7 +1266,8 @@ _cairo_xcb_surface_picture (cairo_xcb_surface_t *target,
if (unlikely (status))
return (cairo_xcb_picture_t *) _cairo_surface_create_in_error (status);
if (image->format != CAIRO_FORMAT_INVALID) {
if (image->format != CAIRO_FORMAT_INVALID &&
image->format < ARRAY_LENGTH (target->screen->connection->standard_formats)) {
xcb_render_pictformat_t format;
format = target->screen->connection->standard_formats[image->format];

View file

@ -0,0 +1,80 @@
/*
* Copyright © 2005 Red Hat, Inc.
* Copyright © 2021 Manuel Stoeckl
*
* Permission to use, copy, modify, distribute, and sell this software
* and its documentation for any purpose is hereby granted without
* fee, provided that the above copyright notice appear in all copies
* and that both that copyright notice and this permission notice
* appear in supporting documentation, and that the name of
* Red Hat, Inc. not be used in advertising or publicity pertaining to
* distribution of the software without specific, written prior
* permission. Red Hat, Inc. makes no representations about the
* suitability of this software for any purpose. It is provided "as
* is" without express or implied warranty.
*
* RED HAT, INC. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS, IN NO EVENT SHALL RED HAT, INC. BE LIABLE FOR ANY SPECIAL,
* INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
* IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
* Author: Carl Worth <cworth@cworth.org>
* Author: Manuel Stoeckl <code@mstoeckl.com>
*/
#include "cairo-test.h"
#include <stdlib.h>
#define WIDTH 2
#define HEIGHT 2
static cairo_test_status_t
draw (cairo_t *cr, int width, int height)
{
const cairo_test_context_t *ctx = cairo_test_get_context (cr);
char *filename;
cairo_surface_t *surface;
xasprintf (&filename, "%s/reference/%s",
ctx->srcdir, "create-from-png-16bit.base.png");
surface = cairo_image_surface_create_from_png (filename);
if (cairo_surface_status (surface)) {
cairo_test_status_t result;
result = cairo_test_status_from_status (ctx,
cairo_surface_status (surface));
if (result == CAIRO_TEST_FAILURE) {
cairo_test_log (ctx, "Error reading PNG image %s: %s\n",
filename,
cairo_status_to_string (cairo_surface_status (surface)));
}
free (filename);
return result;
}
/* Pretend we modify the surface data (which detaches the PNG mime data) */
cairo_surface_flush (surface);
cairo_surface_mark_dirty (surface);
cairo_set_source_surface (cr, surface, 0, 0);
cairo_pattern_set_filter (cairo_get_source (cr), CAIRO_FILTER_NEAREST);
cairo_paint (cr);
cairo_surface_destroy (surface);
free (filename);
return CAIRO_TEST_SUCCESS;
}
CAIRO_TEST (create_from_png_16bit,
"Tests the creation of an image surface from a 16 bit PNG file",
"png", /* keywords */
NULL, /* requirements */
WIDTH, HEIGHT,
NULL, draw)

View file

@ -96,6 +96,7 @@ test_sources = [
'create-for-stream.c',
'create-from-broken-png-stream.c',
'create-from-png.c',
'create-from-png-16bit.c',
'create-from-png-stream.c',
'culled-glyphs.c',
'curve-to-as-line-to.c',

Binary file not shown.

After

Width:  |  Height:  |  Size: 113 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 98 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 98 B

View file

@ -6799,6 +6799,9 @@ _integer_constants[] = {
{ "RGB16_565", CAIRO_FORMAT_RGB16_565 },
{ "RGB24", CAIRO_FORMAT_RGB24 },
{ "ARGB32", CAIRO_FORMAT_ARGB32 },
{ "RGB30", CAIRO_FORMAT_RGB30 },
{ "RGB96F", CAIRO_FORMAT_RGB96F },
{ "RGBA128F", CAIRO_FORMAT_RGBA128F },
{ "INVALID", CAIRO_FORMAT_INVALID },
{ NULL, 0 }