summaryrefslogtreecommitdiff
path: root/external
diff options
context:
space:
mode:
authorJan-Marek Glogowski <glogow@fbihome.de>2021-11-30 19:03:31 +0100
committerJan-Marek Glogowski <glogow@fbihome.de>2021-12-04 08:51:43 +0100
commit2e5d18127f3be6741677bb567f9db37e2f4a9908 (patch)
tree65c34ae2b2f0b940ebb3a091ecf2b17707bedae7 /external
parent885d9427045bb35df842600b060da4ddc4791429 (diff)
Fix cairo function pointer usage
WASM strictly checks function signatures, so forced wrong casting of function pointers compiles, but any call will generate a runtime error, even if the argument is actually ignored. So this adds a bunch of wrapper functions to pass instead. Change-Id: Id976ea3ca81a792c8af539884ef741f5d23fc2c8 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/126317 Tested-by: Jenkins Reviewed-by: Jan-Marek Glogowski <glogow@fbihome.de>
Diffstat (limited to 'external')
-rw-r--r--external/cairo/UnpackedTarball_cairo.mk1
-rw-r--r--external/cairo/cairo/cairo-fix_function_signature.patch.1334
2 files changed, 335 insertions, 0 deletions
diff --git a/external/cairo/UnpackedTarball_cairo.mk b/external/cairo/UnpackedTarball_cairo.mk
index 5e83b526e52e..49a4a726bbe2 100644
--- a/external/cairo/UnpackedTarball_cairo.mk
+++ b/external/cairo/UnpackedTarball_cairo.mk
@@ -18,6 +18,7 @@ $(eval $(call gb_UnpackedTarball_add_patches,cairo,\
external/cairo/cairo/cairo.oldfreetype.patch \
external/cairo/cairo/san.patch.0 \
external/cairo/cairo/0001-Fix-mask-usage-in-image-compositor.patch.1 \
+ external/cairo/cairo/cairo-fix_function_signature.patch.1 \
))
ifeq ($(OS),iOS)
diff --git a/external/cairo/cairo/cairo-fix_function_signature.patch.1 b/external/cairo/cairo/cairo-fix_function_signature.patch.1
new file mode 100644
index 000000000000..41cbc6ffbeab
--- /dev/null
+++ b/external/cairo/cairo/cairo-fix_function_signature.patch.1
@@ -0,0 +1,334 @@
+diff --git a/src/cairo-clip-boxes.c b/src/cairo-clip-boxes.c
+index aaddeb7..0d85051 100644
+--- a/src/cairo-clip-boxes.c
++++ b/src/cairo-clip-boxes.c
+@@ -481,8 +481,9 @@ _add_edge (struct reduce *r,
+ }
+
+ static cairo_status_t
+-_reduce_line_to (void *closure,
+- const cairo_point_t *point)
++_reduce_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ struct reduce *r = closure;
+
+@@ -492,6 +493,13 @@ _reduce_line_to (void *closure,
+ return CAIRO_STATUS_SUCCESS;
+ }
+
++static cairo_status_t
++_reduce_line_to (void *closure,
++ const cairo_point_t *point)
++{
++ return _reduce_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ _reduce_close (void *closure)
+ {
+@@ -547,6 +555,7 @@ _cairo_clip_reduce_to_boxes (cairo_clip_t *clip)
+ status = _cairo_path_fixed_interpret_flat (&clip_path->path,
+ _reduce_move_to,
+ _reduce_line_to,
++ _reduce_add_point,
+ _reduce_close,
+ &r,
+ clip_path->tolerance);
+diff --git a/src/cairo-path-fill.c b/src/cairo-path-fill.c
+index 4000c9c..dd11a91 100644
+--- a/src/cairo-path-fill.c
++++ b/src/cairo-path-fill.c
+@@ -54,8 +54,9 @@ typedef struct cairo_filler {
+ } cairo_filler_t;
+
+ static cairo_status_t
+-_cairo_filler_line_to (void *closure,
+- const cairo_point_t *point)
++_cairo_filler_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ cairo_filler_t *filler = closure;
+ cairo_status_t status;
+@@ -69,6 +70,13 @@ _cairo_filler_line_to (void *closure,
+ return status;
+ }
+
++static cairo_status_t
++_cairo_filler_line_to (void *closure,
++ const cairo_point_t *point)
++{
++ return _cairo_filler_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ _cairo_filler_close (void *closure)
+ {
+@@ -113,7 +121,7 @@ _cairo_filler_curve_to (void *closure,
+ }
+
+ if (! _cairo_spline_init (&spline,
+- (cairo_spline_add_point_func_t)_cairo_filler_line_to, filler,
++ _cairo_filler_add_point, filler,
+ &filler->current_point, p1, p2, p3))
+ {
+ return _cairo_filler_line_to (closure, p3);
+@@ -164,8 +172,9 @@ typedef struct cairo_filler_rectilinear_aligned {
+ } cairo_filler_ra_t;
+
+ static cairo_status_t
+-_cairo_filler_ra_line_to (void *closure,
+- const cairo_point_t *point)
++_cairo_filler_ra_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ cairo_filler_ra_t *filler = closure;
+ cairo_status_t status;
+@@ -183,6 +192,13 @@ _cairo_filler_ra_line_to (void *closure,
+ return status;
+ }
+
++static cairo_status_t
++_cairo_filler_ra_line_to (void *closure,
++ const cairo_point_t *point)
++{
++ return _cairo_filler_ra_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ _cairo_filler_ra_close (void *closure)
+ {
+@@ -234,6 +250,7 @@ _cairo_path_fixed_fill_rectilinear_to_polygon (const cairo_path_fixed_t *path,
+ status = _cairo_path_fixed_interpret_flat (path,
+ _cairo_filler_ra_move_to,
+ _cairo_filler_ra_line_to,
++ _cairo_filler_ra_add_point,
+ _cairo_filler_ra_close,
+ &filler,
+ 0.);
+diff --git a/src/cairo-path-fixed.c b/src/cairo-path-fixed.c
+index d741823..ea7fb9e 100644
+--- a/src/cairo-path-fixed.c
++++ b/src/cairo-path-fixed.c
+@@ -1108,6 +1108,7 @@ typedef struct cairo_path_flattener {
+ cairo_point_t current_point;
+ cairo_path_fixed_move_to_func_t *move_to;
+ cairo_path_fixed_line_to_func_t *line_to;
++ cairo_spline_add_point_func_t add_point;
+ cairo_path_fixed_close_path_func_t *close_path;
+ void *closure;
+ } cpf_t;
+@@ -1124,8 +1125,9 @@ _cpf_move_to (void *closure,
+ }
+
+ static cairo_status_t
+-_cpf_line_to (void *closure,
+- const cairo_point_t *point)
++_cpf_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ cpf_t *cpf = closure;
+
+@@ -1134,6 +1136,13 @@ _cpf_line_to (void *closure,
+ return cpf->line_to (cpf->closure, point);
+ }
+
++static cairo_status_t
++_cpf_line_to (void *closure,
++ const cairo_point_t *point)
++{
++ return _cpf_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ _cpf_curve_to (void *closure,
+ const cairo_point_t *p1,
+@@ -1146,7 +1155,7 @@ _cpf_curve_to (void *closure,
+ cairo_point_t *p0 = &cpf->current_point;
+
+ if (! _cairo_spline_init (&spline,
+- (cairo_spline_add_point_func_t)cpf->line_to,
++ cpf->add_point,
+ cpf->closure,
+ p0, p1, p2, p3))
+ {
+@@ -1170,6 +1179,7 @@ cairo_status_t
+ _cairo_path_fixed_interpret_flat (const cairo_path_fixed_t *path,
+ cairo_path_fixed_move_to_func_t *move_to,
+ cairo_path_fixed_line_to_func_t *line_to,
++ cairo_spline_add_point_func_t add_point,
+ cairo_path_fixed_close_path_func_t *close_path,
+ void *closure,
+ double tolerance)
+@@ -1188,6 +1198,7 @@ _cairo_path_fixed_interpret_flat (const cairo_path_fixed_t *path,
+ flattener.tolerance = tolerance;
+ flattener.move_to = move_to;
+ flattener.line_to = line_to;
++ flattener.add_point = *add_point;
+ flattener.close_path = close_path;
+ flattener.closure = closure;
+ return _cairo_path_fixed_interpret (path,
+diff --git a/src/cairo-path-in-fill.c b/src/cairo-path-in-fill.c
+index 1787fb1..e61500b 100644
+--- a/src/cairo-path-in-fill.c
++++ b/src/cairo-path-in-fill.c
+@@ -169,8 +169,9 @@ _cairo_in_fill_move_to (void *closure,
+ }
+
+ static cairo_status_t
+-_cairo_in_fill_line_to (void *closure,
+- const cairo_point_t *point)
++_cairo_in_fill_spline_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ cairo_in_fill_t *in_fill = closure;
+
+@@ -183,6 +184,13 @@ _cairo_in_fill_line_to (void *closure,
+ return CAIRO_STATUS_SUCCESS;
+ }
+
++static cairo_status_t
++_cairo_in_fill_line_to (void *closure,
++ const cairo_point_t *point)
++{
++ return _cairo_in_fill_spline_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ _cairo_in_fill_curve_to (void *closure,
+ const cairo_point_t *b,
+@@ -217,7 +225,7 @@ _cairo_in_fill_curve_to (void *closure,
+
+ /* XXX Investigate direct inspection of the inflections? */
+ if (! _cairo_spline_init (&spline,
+- (cairo_spline_add_point_func_t)_cairo_in_fill_line_to,
++ _cairo_in_fill_spline_add_point,
+ in_fill,
+ &in_fill->current_point, b, c, d))
+ {
+diff --git a/src/cairo-path-stroke-traps.c b/src/cairo-path-stroke-traps.c
+index 1363ffa..6377bc1 100644
+--- a/src/cairo-path-stroke-traps.c
++++ b/src/cairo-path-stroke-traps.c
+@@ -817,7 +817,9 @@ line_to (void *closure, const cairo_point_t *point)
+ * Dashed lines. Cap each dash end, join around turns when on
+ */
+ static cairo_status_t
+-line_to_dashed (void *closure, const cairo_point_t *point)
++_cairo_in_dashed_spline_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ struct stroker *stroker = closure;
+ double mag, remain, step_length = 0;
+@@ -930,6 +932,12 @@ line_to_dashed (void *closure, const cairo_point_t *point)
+ return CAIRO_STATUS_SUCCESS;
+ }
+
++static cairo_status_t
++line_to_dashed (void *closure, const cairo_point_t *point)
++{
++ return _cairo_in_dashed_spline_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ spline_to (void *closure,
+ const cairo_point_t *point,
+@@ -1042,7 +1050,7 @@ curve_to_dashed (void *closure,
+ cairo_spline_add_point_func_t func;
+ cairo_status_t status;
+
+- func = (cairo_spline_add_point_func_t)line_to_dashed;
++ func = _cairo_in_dashed_spline_add_point;
+
+ if (stroker->has_bounds &&
+ ! _cairo_spline_intersects (&stroker->current_face.point, b, c, d,
+diff --git a/src/cairo-path.c b/src/cairo-path.c
+index 566e86f..5a8f5d6 100644
+--- a/src/cairo-path.c
++++ b/src/cairo-path.c
+@@ -70,8 +70,9 @@ _cpc_move_to (void *closure,
+ }
+
+ static cairo_status_t
+-_cpc_line_to (void *closure,
+- const cairo_point_t *point)
++_cpc_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ cpc_t *cpc = closure;
+
+@@ -80,6 +81,13 @@ _cpc_line_to (void *closure,
+ return CAIRO_STATUS_SUCCESS;
+ }
+
++static cairo_status_t
++_cpc_line_to (void *closure,
++ const cairo_point_t *point)
++{
++ return _cpc_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ _cpc_curve_to (void *closure,
+ const cairo_point_t *p1,
+@@ -118,6 +126,7 @@ _cairo_path_count (cairo_path_t *path,
+ status = _cairo_path_fixed_interpret_flat (path_fixed,
+ _cpc_move_to,
+ _cpc_line_to,
++ _cpc_add_point,
+ _cpc_close_path,
+ &cpc,
+ tolerance);
+@@ -168,8 +177,9 @@ _cpp_move_to (void *closure,
+ }
+
+ static cairo_status_t
+-_cpp_line_to (void *closure,
+- const cairo_point_t *point)
++_cpp_add_point (void *closure,
++ const cairo_point_t *point,
++ const struct _cairo_slope *slope)
+ {
+ cpp_t *cpp = closure;
+ cairo_path_data_t *data = cpp->data;
+@@ -192,6 +202,13 @@ _cpp_line_to (void *closure,
+ return CAIRO_STATUS_SUCCESS;
+ }
+
++static cairo_status_t
++_cpp_line_to (void *closure,
++ const cairo_point_t *point)
++{
++ return _cpp_add_point(closure, point, NULL);
++}
++
+ static cairo_status_t
+ _cpp_curve_to (void *closure,
+ const cairo_point_t *p1,
+@@ -264,6 +281,7 @@ _cairo_path_populate (cairo_path_t *path,
+ status = _cairo_path_fixed_interpret_flat (path_fixed,
+ _cpp_move_to,
+ _cpp_line_to,
++ _cpp_add_point,
+ _cpp_close_path,
+ &cpp,
+ cairo_get_tolerance (cr));
+diff --git a/src/cairoint.h b/src/cairoint.h
+index 7f6a252..edbfe52 100644
+--- a/src/cairoint.h
++++ b/src/cairoint.h
+@@ -1022,6 +1022,7 @@ cairo_private cairo_status_t
+ _cairo_path_fixed_interpret_flat (const cairo_path_fixed_t *path,
+ cairo_path_fixed_move_to_func_t *move_to,
+ cairo_path_fixed_line_to_func_t *line_to,
++ cairo_spline_add_point_func_t add_point,
+ cairo_path_fixed_close_path_func_t *close_path,
+ void *closure,
+ double tolerance);