[librsvg: 2/3] allowed_url: implement deref



commit a7fc45474915826eb3428666637462f19da871b3
Author: Paolo Borelli <pborelli gnome org>
Date:   Mon Jan 14 22:25:34 2019 +0100

    allowed_url: implement deref
    
    Since this is a validated wrapper around Url, dereferencing the
    actual Url is handy

 rsvg_internals/src/allowed_url.rs | 23 ++++++++++++++---------
 rsvg_internals/src/css.rs         |  8 ++++----
 rsvg_internals/src/handle.rs      |  2 +-
 rsvg_internals/src/io.rs          |  4 ++--
 rsvg_internals/src/xml.rs         |  8 ++++----
 5 files changed, 25 insertions(+), 20 deletions(-)
---
diff --git a/rsvg_internals/src/allowed_url.rs b/rsvg_internals/src/allowed_url.rs
index 561b0b80..662493f1 100644
--- a/rsvg_internals/src/allowed_url.rs
+++ b/rsvg_internals/src/allowed_url.rs
@@ -1,6 +1,7 @@
 use std::error::{self, Error};
 use std::fmt;
 use std::io;
+use std::ops::Deref;
 use std::path::{Path, PathBuf};
 use url::{self, Url};
 
@@ -106,8 +107,12 @@ impl AllowedUrl {
             Err(AllowedUrlError::NotSiblingOrChildOfBaseFile)
         }
     }
+}
+
+impl Deref for AllowedUrl {
+    type Target = Url;
 
-    pub fn url(&self) -> &Url {
+    fn deref(&self) -> &Url {
         &self.0
     }
 }
@@ -303,8 +308,8 @@ mod tests {
         assert_eq!(
             AllowedUrl::from_href("", None)
                 .unwrap()
-                .url(),
-            &Url::parse("").unwrap(),
+                .as_ref(),
+            "",
         );
     }
 
@@ -316,8 +321,8 @@ mod tests {
                 Some(Url::parse("file:///example/bar.svg").unwrap()).as_ref()
             )
             .unwrap()
-            .url(),
-            &Url::parse("file:///example/foo.svg").unwrap(),
+            .as_ref(),
+            "file:///example/foo.svg",
         );
     }
 
@@ -329,8 +334,8 @@ mod tests {
                 Some(Url::parse("file:///example/bar.svg").unwrap()).as_ref()
             )
             .unwrap()
-            .url(),
-            &Url::parse("file:///example/foo.svg").unwrap(),
+            .as_ref(),
+            "file:///example/foo.svg",
         );
     }
 
@@ -342,8 +347,8 @@ mod tests {
                 Some(Url::parse("file:///example/bar.svg").unwrap()).as_ref()
             )
             .unwrap()
-            .url(),
-            &Url::parse("file:///example/subdir/foo.svg").unwrap(),
+            .as_ref(),
+            "file:///example/subdir/foo.svg",
         );
     }
 
diff --git a/rsvg_internals/src/css.rs b/rsvg_internals/src/css.rs
index 8cb0129f..d0cbb4e4 100644
--- a/rsvg_internals/src/css.rs
+++ b/rsvg_internals/src/css.rs
@@ -36,7 +36,7 @@ impl CssStyles {
         }
     }
 
-    pub fn parse(&mut self, base_url: Option<Url>, buf: &str) {
+    pub fn parse(&mut self, base_url: Option<&Url>, buf: &str) {
         if buf.len() == 0 {
             return; // libcroco doesn't like empty strings :(
         }
@@ -97,7 +97,7 @@ impl CssStyles {
                 })
             })
             .and_then(|utf8| {
-                self.parse(Some(aurl.url().clone()), &utf8);
+                self.parse(Some(&aurl), &utf8);
                 Ok(()) // FIXME: return CSS parsing errors
             })
     }
@@ -148,7 +148,7 @@ impl CssStyles {
 }
 
 struct DocHandlerData<'a> {
-    base_url: Option<Url>,
+    base_url: Option<&'a Url>,
     css_styles: &'a mut CssStyles,
     selector: *mut CRSelector,
 }
@@ -184,7 +184,7 @@ unsafe extern "C" fn css_import_style(
     let raw_uri = cr_string_peek_raw_str(a_uri);
     let uri = utf8_cstr(raw_uri);
 
-    if let Ok(aurl) = AllowedUrl::from_href(uri, handler_data.base_url.as_ref()) {
+    if let Ok(aurl) = AllowedUrl::from_href(uri, handler_data.base_url) {
         // FIXME: handle CSS errors
         let _ = handler_data.css_styles.load_css(&aurl);
     } else {
diff --git a/rsvg_internals/src/handle.rs b/rsvg_internals/src/handle.rs
index 4eec6f9a..7f0305b8 100644
--- a/rsvg_internals/src/handle.rs
+++ b/rsvg_internals/src/handle.rs
@@ -588,7 +588,7 @@ pub fn lookup_fragment_id(handle: *const RsvgHandle, id: &str) -> Option<Rc<Node
 
 pub fn load_extern(load_options: &LoadOptions, aurl: &AllowedUrl) -> Result<*mut RsvgHandle, ()> {
     unsafe {
-        let file = gio::File::new_for_uri(aurl.url().as_str());
+        let file = gio::File::new_for_uri(aurl.as_str());
 
         let res = rsvg_handle_new_from_gfile_sync(
             file.to_glib_none().0,
diff --git a/rsvg_internals/src/io.rs b/rsvg_internals/src/io.rs
index ea8a66a9..48efb4ef 100644
--- a/rsvg_internals/src/io.rs
+++ b/rsvg_internals/src/io.rs
@@ -80,7 +80,7 @@ pub fn acquire_stream(
     aurl: &AllowedUrl,
     cancellable: Option<&Cancellable>,
 ) -> Result<InputStream, LoadingError> {
-    let uri = aurl.url().as_str();
+    let uri = aurl.as_str();
 
     if uri.starts_with("data:") {
         let BinaryData { data, .. } = decode_data_uri(uri)?;
@@ -100,7 +100,7 @@ pub fn acquire_data(
     aurl: &AllowedUrl,
     cancellable: Option<&Cancellable>,
 ) -> Result<BinaryData, LoadingError> {
-    let uri = aurl.url().as_str();
+    let uri = aurl.as_str();
 
     if uri.starts_with("data:") {
         Ok(decode_data_uri(uri)?)
diff --git a/rsvg_internals/src/xml.rs b/rsvg_internals/src/xml.rs
index 3d6dd20f..8051a591 100644
--- a/rsvg_internals/src/xml.rs
+++ b/rsvg_internals/src/xml.rs
@@ -277,7 +277,7 @@ impl XmlState {
 
             let css_styles = self.css_styles.as_mut().unwrap();
 
-            css_styles.parse(self.load_options.base_url.clone(), &css_data);
+            css_styles.parse(self.load_options.base_url.as_ref(), &css_data);
         }
 
         self.current_node = node.get_parent();
@@ -445,14 +445,14 @@ impl XmlState {
         encoding: Option<&str>,
     ) -> Result<(), AcquireError> {
         let binary = io::acquire_data(aurl, None).map_err(|e| {
-            rsvg_log!("could not acquire \"{}\": {}", aurl.url(), e);
+            rsvg_log!("could not acquire \"{}\": {}", aurl, e);
             AcquireError::ResourceError
         })?;
 
         let encoding = encoding.unwrap_or("utf-8");
 
         let encoder = encoding_from_whatwg_label(encoding).ok_or_else(|| {
-            rsvg_log!("unknown encoding \"{}\" for \"{}\"", encoding, aurl.url());
+            rsvg_log!("unknown encoding \"{}\" for \"{}\"", encoding, aurl);
             AcquireError::FatalError
         })?;
 
@@ -461,7 +461,7 @@ impl XmlState {
             .map_err(|e| {
                 rsvg_log!(
                     "could not convert contents of \"{}\" from character encoding \"{}\": {}",
-                    aurl.url(),
+                    aurl,
                     encoding,
                     e
                 );


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