[librsvg/rustify-rsvg-convert: 3/4] rsvg-convert: move cairo context creation within Surface




commit 122f5496e86bd451508d7cde7721e13fc610ec6b
Author: Paolo Borelli <pborelli gnome org>
Date:   Sun Jan 10 11:05:14 2021 +0100

    rsvg-convert: move cairo context creation within Surface

 src/bin/rsvg-convert/main.rs | 48 ++++++++++++++++++++++++--------------------
 1 file changed, 26 insertions(+), 22 deletions(-)
---
diff --git a/src/bin/rsvg-convert/main.rs b/src/bin/rsvg-convert/main.rs
index 5ea8e58e..861ca21c 100644
--- a/src/bin/rsvg-convert/main.rs
+++ b/src/bin/rsvg-convert/main.rs
@@ -189,16 +189,28 @@ impl Surface {
     pub fn render(
         &self,
         renderer: &CairoRenderer,
-        cr: &cairo::Context,
+        scale: Scale,
+        background_color: Option<Color>,
         id: Option<&str>,
     ) -> Result<(), RenderingError> {
-        renderer
-            .render_layer(cr, id, &self.bounds())
-            .map(|_| {
-                if !matches!(self, Self::Png(_, _)) {
-                    cr.show_page();
-                }
-            })
+        let cr = cairo::Context::new(self);
+
+        if let Some(Color::RGBA(rgba)) = background_color {
+            cr.set_source_rgba(
+                rgba.red_f32().into(),
+                rgba.green_f32().into(),
+                rgba.blue_f32().into(),
+                rgba.alpha_f32().into(),
+            );
+        }
+
+        cr.scale(scale.x, scale.y);
+
+        renderer.render_layer(&cr, id, &self.bounds()).map(|_| {
+            if !matches!(self, Self::Png(_, _)) {
+                cr.show_page();
+            }
+        })
     }
 
     pub fn finish(self) -> Result<(), cairo::IoError> {
@@ -419,21 +431,13 @@ impl Converter {
             }
 
             if let Some(ref surface) = target {
-                let cr = cairo::Context::new(surface);
-
-                if let Some(Color::RGBA(rgba)) = self.background_color {
-                    cr.set_source_rgba(
-                        rgba.red_f32().into(),
-                        rgba.green_f32().into(),
-                        rgba.blue_f32().into(),
-                        rgba.alpha_f32().into(),
-                    );
-                }
-
-                cr.scale(self.zoom.x, self.zoom.y);
-
                 surface
-                    .render(&renderer, &cr, self.export_id.as_deref())
+                    .render(
+                        &renderer,
+                        self.zoom,
+                        self.background_color,
+                        self.export_id.as_deref(),
+                    )
                     .unwrap_or_else(|e| exit!("Error rendering SVG {}: {}", input, e));
             }
         }


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]