blob: 69e648f2fc13e052a6fd4844f77674556220ab32 [file] [log] [blame]
Alex Crichton2e0229c2017-05-23 09:34:50 -07001#![cfg(feature = "extra-traits")]
2
Nika Layzella2a1a4a2017-11-19 11:33:17 -05003#![feature(rustc_private)]
4
David Tolnayb153dbc2016-10-04 23:39:10 -07005extern crate syn;
6use syn::*;
7
David Tolnaye7678922016-10-13 20:44:03 -07008#[macro_use]
9extern crate quote;
David Tolnayb153dbc2016-10-04 23:39:10 -070010
Alex Crichton605643b2017-07-05 18:35:14 -070011extern crate proc_macro2;
12use proc_macro2::Term;
13
David Tolnayc7a5d3d2017-06-04 12:11:05 -070014mod common;
15
David Tolnayb153dbc2016-10-04 23:39:10 -070016#[test]
17fn test_split_for_impl() {
David Tolnaye7678922016-10-13 20:44:03 -070018 // <'a, 'b: 'a, #[may_dangle] T: 'a = ()> where T: Debug
Alex Crichtonccbb45d2017-05-23 10:58:24 -070019 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 Crichton605643b2017-07-05 18:35:14 -070025 lifetime: Lifetime::new(Term::intern("'a"), Span::default()),
Alex Crichtonccbb45d2017-05-23 10:58:24 -070026 bounds: Default::default(),
27 colon_token: None,
28 },
29 LifetimeDef {
30 attrs: Default::default(),
Alex Crichton605643b2017-07-05 18:35:14 -070031 lifetime: Lifetime::new(Term::intern("'b"), Span::default()),
32 bounds: vec![Lifetime::new(Term::intern("'a"), Span::default())].into(),
Alex Crichtonccbb45d2017-05-23 10:58:24 -070033 colon_token: Some(tokens::Colon::default()),
34 },
35 ].into(),
36 ty_params: vec![
David Tolnayfd6bf5c2017-11-12 09:41:14 -080037 TypeParam {
Alex Crichtonccbb45d2017-05-23 10:58:24 -070038 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 Tolnayfd6bf5c2017-11-12 09:41:14 -080047 bounds: vec![TypeParamBound::Region(Lifetime::new(Term::intern("'a"), Span::default()))].into(),
48 default: Some(TypeTup {
Alex Crichtonccbb45d2017-05-23 10:58:24 -070049 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 Tolnayb153dbc2016-10-04 23:39:10 -070057 where_clause: WhereClause {
Alex Crichtonccbb45d2017-05-23 10:58:24 -070058 where_token: Some(Default::default()),
59 predicates: vec![
60 WherePredicate::BoundPredicate(WhereBoundPredicate {
61 bound_lifetimes: None,
62 colon_token: Default::default(),
David Tolnayfd6bf5c2017-11-12 09:41:14 -080063 bounded_ty: TypePath {
Alex Crichtonccbb45d2017-05-23 10:58:24 -070064 qself: None,
65 path: "T".into(),
66 }.into(),
67 bounds: vec![
David Tolnayfd6bf5c2017-11-12 09:41:14 -080068 TypeParamBound::Trait(
David Tolnayb153dbc2016-10-04 23:39:10 -070069 PolyTraitRef {
Alex Crichtonccbb45d2017-05-23 10:58:24 -070070 bound_lifetimes: None,
David Tolnaye7678922016-10-13 20:44:03 -070071 trait_ref: "Debug".into(),
David Tolnayb153dbc2016-10-04 23:39:10 -070072 },
73 TraitBoundModifier::None,
74 ),
Alex Crichtonccbb45d2017-05-23 10:58:24 -070075 ].into(),
76 })
77 ].into(),
David Tolnayb153dbc2016-10-04 23:39:10 -070078 },
79 };
Alex Crichtonccbb45d2017-05-23 10:58:24 -070080 generics.lifetimes.push_trailing(Default::default());
David Tolnayb153dbc2016-10-04 23:39:10 -070081
82 let (impl_generics, ty_generics, where_clause) = generics.split_for_impl();
David Tolnaye7678922016-10-13 20:44:03 -070083 let tokens = quote! {
84 impl #impl_generics MyTrait for Test #ty_generics #where_clause {}
David Tolnayb153dbc2016-10-04 23:39:10 -070085 };
David Tolnay93413a52016-10-24 13:02:36 -070086 let expected = concat!("impl < 'a , 'b : 'a , # [ may_dangle ] T : 'a > ",
87 "MyTrait for Test < 'a , 'b , T > ",
88 "where T : Debug { }");
David Tolnayc879a502017-01-25 15:51:32 -080089 assert_eq!(expected, tokens.to_string());
David Tolnayb153dbc2016-10-04 23:39:10 -070090
David Tolnayc879a502017-01-25 15:51:32 -080091 let turbofish = ty_generics.as_turbofish();
92 let tokens = quote! {
93 Test #turbofish
94 };
95 let expected = "Test :: < 'a , 'b , T >";
David Tolnaye7678922016-10-13 20:44:03 -070096 assert_eq!(expected, tokens.to_string());
David Tolnayb153dbc2016-10-04 23:39:10 -070097}
David Tolnay23d83f92017-01-25 15:41:47 -080098
99#[test]
100fn test_ty_param_bound() {
101 let tokens = quote!('a);
David Tolnayfd6bf5c2017-11-12 09:41:14 -0800102 let expected = TypeParamBound::Region(Lifetime::new(Term::intern("'a"), Span::default()));
103 assert_eq!(expected, common::parse::syn::<TypeParamBound>(tokens.into()));
David Tolnay23d83f92017-01-25 15:41:47 -0800104
105 let tokens = quote!(Debug);
David Tolnayfd6bf5c2017-11-12 09:41:14 -0800106 let expected = TypeParamBound::Trait(
Alex Crichtonccbb45d2017-05-23 10:58:24 -0700107 PolyTraitRef {
108 bound_lifetimes: None,
109 trait_ref: "Debug".into(),
110 },
111 TraitBoundModifier::None);
David Tolnayfd6bf5c2017-11-12 09:41:14 -0800112 assert_eq!(expected, common::parse::syn::<TypeParamBound>(tokens.into()));
David Tolnay23d83f92017-01-25 15:41:47 -0800113
114 let tokens = quote!(?Sized);
David Tolnayfd6bf5c2017-11-12 09:41:14 -0800115 let expected = TypeParamBound::Trait(
Alex Crichtonccbb45d2017-05-23 10:58:24 -0700116 PolyTraitRef {
117 bound_lifetimes: None,
118 trait_ref: "Sized".into(),
119 },
120 TraitBoundModifier::Maybe(Default::default()));
David Tolnayfd6bf5c2017-11-12 09:41:14 -0800121 assert_eq!(expected, common::parse::syn::<TypeParamBound>(tokens.into()));
David Tolnay23d83f92017-01-25 15:41:47 -0800122}