[cairo-commit] 2 commits - src/cairo-recording-surface.c test/bug-448.c test/Makefile.sources
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Mon Jan 4 15:12:40 UTC 2021
src/cairo-recording-surface.c | 8 ++--
test/Makefile.sources | 1
test/bug-448.c | 76 ++++++++++++++++++++++++++++++++++++++++++
3 files changed, 81 insertions(+), 4 deletions(-)
New commits:
commit 7ac8220c1fd4afb259e53b7a5cd93a23859bdbda
Merge: ed7e51eb4 a1dc600a0
Author: Heiko Lewin <hlewin at gmx.de>
Date: Mon Jan 4 15:12:38 2021 +0000
Merge branch 'fix-copy-paste-error-in-recording-surfaces' into 'master'
Fix copying tags in a recording surface
Closes #448
See merge request cairo/cairo!93
commit a1dc600a07f89b9c08ffa8c25dc92f75fec10dd6
Author: Uli Schlachter <psychon at znc.in>
Date: Sat Dec 26 16:17:58 2020 +0100
Fix copying tags in a recording surface
The code was copying from the wrong member of an union. This caused a
huge num_dashes value to be read, which then caused a so large memory
allocation that malloc returned an error.
Fixes: https://gitlab.freedesktop.org/cairo/cairo/-/issues/448
Signed-off-by: Uli Schlachter <psychon at znc.in>
diff --git a/src/cairo-recording-surface.c b/src/cairo-recording-surface.c
index 6df8b0821..393eecca5 100644
--- a/src/cairo-recording-surface.c
+++ b/src/cairo-recording-surface.c
@@ -1456,17 +1456,17 @@ _cairo_recording_surface_copy__tag (cairo_recording_surface_t *surface,
command->attributes = strdup (src->tag.attributes);
status = _cairo_pattern_init_copy (&command->source.base,
- &src->stroke.source.base);
+ &src->tag.source.base);
if (unlikely (status))
goto err_command;
status = _cairo_stroke_style_init_copy (&command->style,
- &src->stroke.style);
+ &src->tag.style);
if (unlikely (status))
goto err_source;
- command->ctm = src->stroke.ctm;
- command->ctm_inverse = src->stroke.ctm_inverse;
+ command->ctm = src->tag.ctm;
+ command->ctm_inverse = src->tag.ctm_inverse;
}
status = _cairo_recording_surface_commit (surface, &command->header);
diff --git a/test/Makefile.sources b/test/Makefile.sources
index 86494348d..1a04ae03b 100644
--- a/test/Makefile.sources
+++ b/test/Makefile.sources
@@ -25,6 +25,7 @@ test_sources = \
big-trap.c \
bilevel-image.c \
bug-40410.c \
+ bug-448.c \
bug-51910.c \
bug-75705.c \
bug-84115.c \
diff --git a/test/bug-448.c b/test/bug-448.c
new file mode 100644
index 000000000..1a459ab5f
--- /dev/null
+++ b/test/bug-448.c
@@ -0,0 +1,76 @@
+/*
+ * Copyright © 2020 Ben Pfaff & Uli Schlachter
+ *
+ * Permission is hereby granted, free of charge, to any person
+ * obtaining a copy of this software and associated documentation
+ * files (the "Software"), to deal in the Software without
+ * restriction, including without limitation the rights to use, copy,
+ * modify, merge, publish, distribute, sublicense, and/or sell copies
+ * of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be
+ * included in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
+ * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
+ * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+ * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ *
+ * Authors:
+ * Ben Pfaff <blp at cs.stanford.edu>
+ * Uli Schlachter <psychon at znc.in>
+ */
+
+#include "cairo-test.h"
+
+static cairo_surface_t*
+draw_recording ()
+{
+ cairo_surface_t *recording;
+ cairo_rectangle_t extents;
+ cairo_t *cr;
+
+ extents.x = 0;
+ extents.y = 0;
+ extents.width = 10;
+ extents.height = 10;
+
+ recording = cairo_recording_surface_create (CAIRO_CONTENT_COLOR_ALPHA, &extents);
+
+ cr = cairo_create(recording);
+ cairo_tag_begin (cr, CAIRO_TAG_DEST, "name='dest'");
+ cairo_rectangle (cr, 3, 3, 4, 4);
+ cairo_stroke (cr);
+ cairo_tag_end (cr, CAIRO_TAG_DEST);
+ cairo_destroy(cr);
+
+ return recording;
+}
+
+static cairo_test_status_t
+draw (cairo_t *cr, int width, int height)
+{
+ cairo_surface_t *recording;
+
+ cairo_set_source_rgb (cr, 1, 1, 1);
+ cairo_paint (cr);
+
+ recording = draw_recording ();
+ cairo_set_source_surface (cr, recording, 0, 0);
+ cairo_paint (cr);
+ cairo_surface_destroy (recording);
+
+ return CAIRO_TEST_SUCCESS;
+}
+
+CAIRO_TEST (bug_448,
+ "Exercises a bug with the tag API",
+ "pdf", /* keywords */
+ NULL, /* requirements */
+ 10, 10,
+ NULL, draw)
More information about the cairo-commit
mailing list