summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNadrieril2020-04-05 16:42:04 +0100
committerNadrieril2020-04-05 16:42:04 +0100
commit118c02d330865fcbfb1f2b0028f9404d61b662d8 (patch)
treed6ab6f280acd80c8d65dc351e857bbbffe0155d6
parent797241ebec5cec686056b5da73864db8eab03d48 (diff)
Borrow type annotation
Diffstat (limited to '')
-rw-r--r--serde_dhall/src/options.rs18
1 files changed, 8 insertions, 10 deletions
diff --git a/serde_dhall/src/options.rs b/serde_dhall/src/options.rs
index a20891a..0f18091 100644
--- a/serde_dhall/src/options.rs
+++ b/serde_dhall/src/options.rs
@@ -15,7 +15,7 @@ enum Source<'a> {
#[derive(Debug, Clone)]
pub struct NoAnnot;
#[derive(Debug, Clone)]
-pub struct ManualAnnot(SimpleType);
+pub struct ManualAnnot<'ty>(&'ty SimpleType);
#[derive(Debug, Clone)]
pub struct StaticAnnot;
@@ -27,8 +27,8 @@ impl<T> HasAnnot<NoAnnot> for T {
None
}
}
-impl<T> HasAnnot<ManualAnnot> for T {
- fn get_annot(a: &ManualAnnot) -> Option<SimpleType> {
+impl<'ty, T> HasAnnot<ManualAnnot<'ty>> for T {
+ fn get_annot(a: &ManualAnnot<'ty>) -> Option<SimpleType> {
Some(a.0.clone())
}
}
@@ -38,7 +38,7 @@ impl<T: StaticType> HasAnnot<StaticAnnot> for T {
}
}
-/// Controls how a dhall value is read.
+/// Controls how a Dhall value is read.
///
/// This builder exposes the ability to configure how a value is deserialized and what operations
/// are permitted during evaluation.
@@ -102,9 +102,7 @@ impl<'a> Deserializer<'a, NoAnnot> {
// fn from_url(url: &'a str) -> Self {
// Self::default_with_source(Source::Url(url))
// }
-}
-impl<'a> Deserializer<'a, NoAnnot> {
/// Ensures that the parsed value matches the provided type.
///
/// In many cases the Dhall type that corresponds to a Rust type can be inferred automatically.
@@ -149,12 +147,12 @@ impl<'a> Deserializer<'a, NoAnnot> {
///
/// [`static_type_annotation`]: struct.Deserializer.html#method.static_type_annotation
/// [`StaticType`]: trait.StaticType.html
- pub fn type_annotation(
+ pub fn type_annotation<'ty>(
self,
- ty: &SimpleType,
- ) -> Deserializer<'a, ManualAnnot> {
+ ty: &'ty SimpleType,
+ ) -> Deserializer<'a, ManualAnnot<'ty>> {
Deserializer {
- annot: ManualAnnot(ty.clone()),
+ annot: ManualAnnot(ty),
source: self.source,
allow_imports: self.allow_imports,
}