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