Alex Crichton | 2e0229c | 2017-05-23 09:34:50 -0700 | [diff] [blame] | 1 | #![cfg(feature = "extra-traits")] |
| 2 | |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 3 | extern crate syn; |
| 4 | use syn::*; |
| 5 | |
David Tolnay | e767892 | 2016-10-13 20:44:03 -0700 | [diff] [blame] | 6 | #[macro_use] |
| 7 | extern crate quote; |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 8 | |
Alex Crichton | 605643b | 2017-07-05 18:35:14 -0700 | [diff] [blame] | 9 | extern crate proc_macro2; |
| 10 | use proc_macro2::Term; |
| 11 | |
David Tolnay | c7a5d3d | 2017-06-04 12:11:05 -0700 | [diff] [blame] | 12 | mod common; |
| 13 | |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 14 | #[test] |
| 15 | fn test_split_for_impl() { |
David Tolnay | e767892 | 2016-10-13 20:44:03 -0700 | [diff] [blame] | 16 | // <'a, 'b: 'a, #[may_dangle] T: 'a = ()> where T: Debug |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 17 | let mut generics = Generics { |
| 18 | gt_token: Some(Default::default()), |
| 19 | lt_token: Some(Default::default()), |
| 20 | lifetimes: vec![ |
| 21 | LifetimeDef { |
| 22 | attrs: Default::default(), |
Alex Crichton | 605643b | 2017-07-05 18:35:14 -0700 | [diff] [blame] | 23 | lifetime: Lifetime::new(Term::intern("'a"), Span::default()), |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 24 | bounds: Default::default(), |
| 25 | colon_token: None, |
| 26 | }, |
| 27 | LifetimeDef { |
| 28 | attrs: Default::default(), |
Alex Crichton | 605643b | 2017-07-05 18:35:14 -0700 | [diff] [blame] | 29 | lifetime: Lifetime::new(Term::intern("'b"), Span::default()), |
| 30 | bounds: vec![Lifetime::new(Term::intern("'a"), Span::default())].into(), |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 31 | colon_token: Some(tokens::Colon::default()), |
| 32 | }, |
| 33 | ].into(), |
| 34 | ty_params: vec![ |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 35 | TypeParam { |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 36 | attrs: vec![Attribute { |
| 37 | bracket_token: Default::default(), |
| 38 | pound_token: Default::default(), |
| 39 | style: AttrStyle::Outer, |
| 40 | path: "may_dangle".into(), |
| 41 | tts: vec![], |
| 42 | is_sugared_doc: false, |
| 43 | }], |
| 44 | ident: "T".into(), |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 45 | bounds: vec![TypeParamBound::Region(Lifetime::new(Term::intern("'a"), Span::default()))].into(), |
| 46 | default: Some(TypeTup { |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 47 | tys: Default::default(), |
| 48 | lone_comma: None, |
| 49 | paren_token: Default::default(), |
| 50 | }.into()), |
| 51 | colon_token: Some(Default::default()), |
| 52 | eq_token: Default::default(), |
| 53 | }, |
| 54 | ].into(), |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 55 | where_clause: WhereClause { |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 56 | where_token: Some(Default::default()), |
| 57 | predicates: vec![ |
| 58 | WherePredicate::BoundPredicate(WhereBoundPredicate { |
| 59 | bound_lifetimes: None, |
| 60 | colon_token: Default::default(), |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 61 | bounded_ty: TypePath { |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 62 | qself: None, |
| 63 | path: "T".into(), |
| 64 | }.into(), |
| 65 | bounds: vec![ |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 66 | TypeParamBound::Trait( |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 67 | PolyTraitRef { |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 68 | bound_lifetimes: None, |
David Tolnay | e767892 | 2016-10-13 20:44:03 -0700 | [diff] [blame] | 69 | trait_ref: "Debug".into(), |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 70 | }, |
| 71 | TraitBoundModifier::None, |
| 72 | ), |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 73 | ].into(), |
| 74 | }) |
| 75 | ].into(), |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 76 | }, |
| 77 | }; |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 78 | generics.lifetimes.push_trailing(Default::default()); |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 79 | |
| 80 | let (impl_generics, ty_generics, where_clause) = generics.split_for_impl(); |
David Tolnay | e767892 | 2016-10-13 20:44:03 -0700 | [diff] [blame] | 81 | let tokens = quote! { |
| 82 | impl #impl_generics MyTrait for Test #ty_generics #where_clause {} |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 83 | }; |
David Tolnay | 93413a5 | 2016-10-24 13:02:36 -0700 | [diff] [blame] | 84 | let expected = concat!("impl < 'a , 'b : 'a , # [ may_dangle ] T : 'a > ", |
| 85 | "MyTrait for Test < 'a , 'b , T > ", |
| 86 | "where T : Debug { }"); |
David Tolnay | c879a50 | 2017-01-25 15:51:32 -0800 | [diff] [blame] | 87 | assert_eq!(expected, tokens.to_string()); |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 88 | |
David Tolnay | c879a50 | 2017-01-25 15:51:32 -0800 | [diff] [blame] | 89 | let turbofish = ty_generics.as_turbofish(); |
| 90 | let tokens = quote! { |
| 91 | Test #turbofish |
| 92 | }; |
| 93 | let expected = "Test :: < 'a , 'b , T >"; |
David Tolnay | e767892 | 2016-10-13 20:44:03 -0700 | [diff] [blame] | 94 | assert_eq!(expected, tokens.to_string()); |
David Tolnay | b153dbc | 2016-10-04 23:39:10 -0700 | [diff] [blame] | 95 | } |
David Tolnay | 23d83f9 | 2017-01-25 15:41:47 -0800 | [diff] [blame] | 96 | |
| 97 | #[test] |
| 98 | fn test_ty_param_bound() { |
| 99 | let tokens = quote!('a); |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 100 | let expected = TypeParamBound::Region(Lifetime::new(Term::intern("'a"), Span::default())); |
| 101 | assert_eq!(expected, common::parse::syn::<TypeParamBound>(tokens.into())); |
David Tolnay | 23d83f9 | 2017-01-25 15:41:47 -0800 | [diff] [blame] | 102 | |
| 103 | let tokens = quote!(Debug); |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 104 | let expected = TypeParamBound::Trait( |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 105 | PolyTraitRef { |
| 106 | bound_lifetimes: None, |
| 107 | trait_ref: "Debug".into(), |
| 108 | }, |
| 109 | TraitBoundModifier::None); |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 110 | assert_eq!(expected, common::parse::syn::<TypeParamBound>(tokens.into())); |
David Tolnay | 23d83f9 | 2017-01-25 15:41:47 -0800 | [diff] [blame] | 111 | |
| 112 | let tokens = quote!(?Sized); |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 113 | let expected = TypeParamBound::Trait( |
Alex Crichton | ccbb45d | 2017-05-23 10:58:24 -0700 | [diff] [blame] | 114 | PolyTraitRef { |
| 115 | bound_lifetimes: None, |
| 116 | trait_ref: "Sized".into(), |
| 117 | }, |
| 118 | TraitBoundModifier::Maybe(Default::default())); |
David Tolnay | fd6bf5c | 2017-11-12 09:41:14 -0800 | [diff] [blame^] | 119 | assert_eq!(expected, common::parse::syn::<TypeParamBound>(tokens.into())); |
David Tolnay | 23d83f9 | 2017-01-25 15:41:47 -0800 | [diff] [blame] | 120 | } |