diff --git a/diesel_derives/src/lib.rs b/diesel_derives/src/lib.rs index b1dceb5f86fd..45b65598f42f 100644 --- a/diesel_derives/src/lib.rs +++ b/diesel_derives/src/lib.rs @@ -1630,8 +1630,29 @@ pub fn table_proc(input: TokenStream) -> TokenStream { /// * `diesel::sql_types::Timestamp` /// /// Support for additional types can be added by providing manual implementations of -/// `HasSqlType`, `FromSql` and `ToSql` for the corresponding type + the generated -/// database backend. +/// `HasSqlType`, `FromSql` and `ToSql` for the corresponding type, all databases included +/// in your enum, and the backend generated by this derive called MultiBackend. +/// For example to support `diesel::sql_types::TimestamptzSqlite` with the `time` crate: +/// ``` +/// impl HasSqlType for MultiBackend { +/// fn metadata(lookup: &mut Self::MetadataLookup) -> Self::TypeMetadata { +/// MultiBackend::lookup_sql_type::(lookup) +/// } +/// } +/// +/// impl FromSql for OffsetDateTime { +/// fn from_sql(bytes: ::RawValue<'_>) -> deserialize::Result { +/// bytes.from_sql::() +/// } +/// } +/// +/// impl ToSql for OffsetDateTime { +/// fn to_sql<'b>(&'b self, out: &mut serialize::Output<'b, '_, MultiBackend>) -> serialize::Result { +/// out.set_value((TimestamptzSqlite, self)); +/// Ok(IsNull::No) +/// } +/// } +/// ``` #[proc_macro_derive(MultiConnection)] pub fn derive_multiconnection(input: TokenStream) -> TokenStream { multiconnection::derive(syn::parse_macro_input!(input)).into()