summaryrefslogtreecommitdiffstats
path: root/src/extension/internal/cairo-render-context.cpp
diff options
context:
space:
mode:
authorKees Cook <kees@outflux.net>2007-12-10 00:48:29 +0000
committerkeescook <keescook@users.sourceforge.net>2007-12-10 00:48:29 +0000
commitc79a5c96989fa96d5ab3f63bb488ee70adb77fb7 (patch)
treefeecb11ba0b8fe0ce60840e4340831e81dbac691 /src/extension/internal/cairo-render-context.cpp
parentbump minimum required gtk to 2.10 (released july 2006), for future print dialog (diff)
downloadinkscape-c79a5c96989fa96d5ab3f63bb488ee70adb77fb7.tar.gz
inkscape-c79a5c96989fa96d5ab3f63bb488ee70adb77fb7.zip
always build cairo backend; add interface for setting cairo surface to renderer
(bzr r4198)
Diffstat (limited to 'src/extension/internal/cairo-render-context.cpp')
-rw-r--r--src/extension/internal/cairo-render-context.cpp22
1 files changed, 18 insertions, 4 deletions
diff --git a/src/extension/internal/cairo-render-context.cpp b/src/extension/internal/cairo-render-context.cpp
index 61d40ea4e..8f106f55f 100644
--- a/src/extension/internal/cairo-render-context.cpp
+++ b/src/extension/internal/cairo-render-context.cpp
@@ -16,8 +16,6 @@
# include "config.h"
#endif
-#ifdef HAVE_CAIRO_PDF
-
#ifndef PANGO_ENABLE_BACKEND
#define PANGO_ENABLE_BACKEND
#endif
@@ -672,6 +670,24 @@ CairoRenderContext::setupSurface(double width, double height)
break;
}
+ return _finishSurfaceSetup (surface);
+}
+
+bool
+CairoRenderContext::setSurface(cairo_surface_t *surface)
+{
+ if (_is_valid || !surface)
+ return false;
+
+ bool ret = _finishSurfaceSetup (surface);
+ if (ret)
+ cairo_surface_reference (surface);
+ return ret;
+}
+
+bool
+CairoRenderContext::_finishSurfaceSetup(cairo_surface_t *surface)
+{
_cr = cairo_create(surface);
_surface = surface;
@@ -1502,8 +1518,6 @@ _write_callback(void *closure, const unsigned char *data, unsigned int length)
/* End of GNU GPL code */
-#endif /* HAVE_CAIRO_PDF */
-
/*
Local Variables: