mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-21 06:28:11 +00:00
Fix infinite recursion in Structure::to_string()
Instead of StructureRef's to_string(), we were calling ToString::to_string() in the Display impl. Which then called into itself again. Fixes https://github.com/sdroege/gstreamer-rs/issues/101
This commit is contained in:
parent
92341e92ca
commit
7c01e1e46f
1 changed files with 6 additions and 4 deletions
|
@ -116,13 +116,15 @@ impl Drop for Structure {
|
||||||
|
|
||||||
impl fmt::Debug for Structure {
|
impl fmt::Debug for Structure {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
f.debug_tuple("Structure").field(&self.to_string()).finish()
|
f.debug_tuple("Structure")
|
||||||
|
.field(&self.as_ref().to_string())
|
||||||
|
.finish()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl fmt::Display for Structure {
|
impl fmt::Display for Structure {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
f.write_str(&self.to_string())
|
f.write_str(&self.as_ref().to_string())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -485,7 +487,7 @@ impl StructureRef {
|
||||||
|
|
||||||
impl fmt::Debug for StructureRef {
|
impl fmt::Debug for StructureRef {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
f.write_str(&self.to_string())
|
f.write_str(&StructureRef::to_string(self))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -676,7 +678,7 @@ mod tests {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_string_conversion() {
|
fn test_string_conversion() {
|
||||||
let a = "Test, f1=(string)abc, f2=(uint)123";
|
let a = "Test, f1=(string)abc, f2=(uint)123;";
|
||||||
|
|
||||||
let s = Structure::from_string(&a).unwrap();
|
let s = Structure::from_string(&a).unwrap();
|
||||||
assert_eq!(s.get::<&str>("f1").unwrap(), "abc");
|
assert_eq!(s.get::<&str>("f1").unwrap(), "abc");
|
||||||
|
|
Loading…
Reference in a new issue