Skip to content

Commit

Permalink
Revert "Derive PgHasArrayType for transparent sqlx types (#1748)"
Browse files Browse the repository at this point in the history
This reverts commit f539215
  • Loading branch information
abonander committed Apr 15, 2022
1 parent 2e026ca commit 8a7b554
Show file tree
Hide file tree
Showing 2 changed files with 1 addition and 30 deletions.
17 changes: 1 addition & 16 deletions sqlx-macros/src/derives/type.rs
Original file line number Diff line number Diff line change
Expand Up @@ -60,22 +60,15 @@ fn expand_derive_has_sql_type_transparent(

if attr.transparent {
let mut generics = generics.clone();
let mut array_generics = generics.clone();

generics
.params
.insert(0, parse_quote!(DB: ::sqlx::Database));
generics
.make_where_clause()
.predicates
.push(parse_quote!(#ty: ::sqlx::Type<DB>));
let (impl_generics, _, where_clause) = generics.split_for_impl();

array_generics
.make_where_clause()
.predicates
.push(parse_quote!(#ty: ::sqlx::postgres::PgHasArrayType));
let (array_impl_generics, _, array_where_clause) = array_generics.split_for_impl();
let (impl_generics, _, where_clause) = generics.split_for_impl();

return Ok(quote!(
#[automatically_derived]
Expand All @@ -88,14 +81,6 @@ fn expand_derive_has_sql_type_transparent(
<#ty as ::sqlx::Type<DB>>::compatible(ty)
}
}
#[automatically_derived]
#[cfg(feature = "postgres")]
impl #array_impl_generics ::sqlx::postgres::PgHasArrayType for #ident #ty_generics
#array_where_clause {
fn array_type_info() -> ::sqlx::postgres::PgTypeInfo {
<#ty as ::sqlx::postgres::PgHasArrayType>::array_type_info()
}
}
));
}

Expand Down
14 changes: 0 additions & 14 deletions tests/postgres/derives.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,20 +10,6 @@ use std::ops::Bound;
#[sqlx(transparent)]
struct Transparent(i32);

#[sqlx_macros::test]
async fn test_transparent_slice_to_array() -> anyhow::Result<()> {
let mut conn = new::<Postgres>().await?;

let values = vec![Transparent(1), Transparent(2), Transparent(3)];

sqlx::query("SELECT 2 = ANY($1);")
.bind(&values)
.fetch_one(&mut conn)
.await?;

Ok(())
}

// "Weak" enums map to an integer type indicated by #[repr]
#[derive(PartialEq, Copy, Clone, Debug, sqlx::Type)]
#[repr(i32)]
Expand Down

0 comments on commit 8a7b554

Please sign in to comment.