From 66f4140e73e423bfed640cfde5cb50c08cf29e2e Mon Sep 17 00:00:00 2001 From: Kouhei Sutou Date: Mon, 28 Oct 2013 22:37:54 +0900 Subject: [PATCH] cairo_create(): Add finished surface check Without this change, the following program crashes: #include #include int main(int argc, char **argv) { cairo_t *cr; cairo_surface_t *finished_surface; finished_surface = cairo_svg_surface_create ("/tmp/xxx.svg", 1.0, 1.0); cairo_surface_finish (finished_surface); cr = cairo_create (finished_surface); cairo_destroy (cr); cairo_surface_destroy (finished_surface); return 0; } Reviewed-by: Bryce Harrington --- src/cairo.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/cairo.c b/src/cairo.c index c7128ae50..e3acf4d46 100644 --- a/src/cairo.c +++ b/src/cairo.c @@ -230,6 +230,8 @@ cairo_create (cairo_surface_t *target) return _cairo_create_in_error (_cairo_error (CAIRO_STATUS_NULL_POINTER)); if (unlikely (target->status)) return _cairo_create_in_error (target->status); + if (unlikely (target->finished)) + return _cairo_create_in_error (_cairo_error (CAIRO_STATUS_SURFACE_FINISHED)); if (target->backend->create_context == NULL) return _cairo_create_in_error (_cairo_error (CAIRO_STATUS_WRITE_ERROR));