summaryrefslogtreecommitdiff
path: root/source
diff options
context:
space:
mode:
authorTor Andersson <tor.andersson@artifex.com>2018-10-10 16:46:15 +0200
committerTor Andersson <tor.andersson@artifex.com>2018-10-23 17:23:59 +0200
commit7b7b4de12bc50f97bd8fd32403319c6d1a758a90 (patch)
tree8fa91fb1c96fc1f46de8dddcbdca8b7671c5e3d0 /source
parentca01073483cbb63a77e3cd2e39993c7dd26fe856 (diff)
downloadmupdf-7b7b4de12bc50f97bd8fd32403319c6d1a758a90.tar.xz
Allow SVG output to keep ID numbers unique across pages.
This is required if embedding multiple SVG documents in a web page, for example.
Diffstat (limited to 'source')
-rw-r--r--source/fitz/output-svg.c3
-rw-r--r--source/fitz/svg-device.c9
-rw-r--r--source/tools/mudraw.c2
3 files changed, 10 insertions, 4 deletions
diff --git a/source/fitz/output-svg.c b/source/fitz/output-svg.c
index 92d158e9..c5215775 100644
--- a/source/fitz/output-svg.c
+++ b/source/fitz/output-svg.c
@@ -16,6 +16,7 @@ struct fz_svg_writer_s
fz_output *out;
int text_format;
int reuse_images;
+ int id;
};
const char *fz_svg_write_options_usage =
@@ -39,7 +40,7 @@ svg_begin_page(fz_context *ctx, fz_document_writer *wri_, fz_rect mediabox)
fz_format_output_path(ctx, path, sizeof path, wri->path, wri->count);
wri->out = fz_new_output_with_path(ctx, path, 0);
- return fz_new_svg_device(ctx, wri->out, w, h, wri->text_format, wri->reuse_images);
+ return fz_new_svg_device(ctx, wri->out, w, h, wri->text_format, wri->reuse_images, &wri->id);
}
static void
diff --git a/source/fitz/svg-device.c b/source/fitz/svg-device.c
index d0d9f50e..7d2c7ee3 100644
--- a/source/fitz/svg-device.c
+++ b/source/fitz/svg-device.c
@@ -53,6 +53,7 @@ struct svg_device_s
fz_buffer *defs_buffer;
int def_count;
+ int *save_id;
int id;
int num_tiles;
@@ -1196,6 +1197,9 @@ svg_dev_close_device(fz_context *ctx, fz_device *dev)
sdev->layers--;
}
+ if (sdev->save_id)
+ *sdev->save_id = sdev->id;
+
fz_write_printf(ctx, out, "</svg>\n");
}
@@ -1221,7 +1225,7 @@ svg_dev_drop_device(fz_context *ctx, fz_device *dev)
fz_free(ctx, sdev->images);
}
-fz_device *fz_new_svg_device(fz_context *ctx, fz_output *out, float page_width, float page_height, int text_format, int reuse_images)
+fz_device *fz_new_svg_device(fz_context *ctx, fz_output *out, float page_width, float page_height, int text_format, int reuse_images, int *id)
{
svg_device *dev = fz_new_derived_device(ctx, svg_device);
@@ -1261,7 +1265,8 @@ fz_device *fz_new_svg_device(fz_context *ctx, fz_output *out, float page_width,
dev->out = out;
dev->out_store = out;
- dev->id = 0;
+ dev->save_id = id;
+ dev->id = id ? *id : 0;
dev->layers = 0;
dev->text_as_text = (text_format == FZ_SVG_TEXT_AS_TEXT);
dev->reuse_images = reuse_images;
diff --git a/source/tools/mudraw.c b/source/tools/mudraw.c
index ecf45ae4..720deeb7 100644
--- a/source/tools/mudraw.c
+++ b/source/tools/mudraw.c
@@ -683,7 +683,7 @@ static void dodrawpage(fz_context *ctx, fz_page *page, fz_display_list *list, in
out = fz_new_output_with_path(ctx, buf, 0);
}
- dev = fz_new_svg_device(ctx, out, tbounds.x1-tbounds.x0, tbounds.y1-tbounds.y0, FZ_SVG_TEXT_AS_PATH, 1);
+ dev = fz_new_svg_device(ctx, out, tbounds.x1-tbounds.x0, tbounds.y1-tbounds.y0, FZ_SVG_TEXT_AS_PATH, 1, NULL);
if (lowmemory)
fz_enable_device_hints(ctx, dev, FZ_NO_CACHE);
if (list)