summaryrefslogtreecommitdiffstats
path: root/src/test/ui/stability-attribute/generics-default-stability.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/ui/stability-attribute/generics-default-stability.rs')
-rw-r--r--src/test/ui/stability-attribute/generics-default-stability.rs251
1 files changed, 251 insertions, 0 deletions
diff --git a/src/test/ui/stability-attribute/generics-default-stability.rs b/src/test/ui/stability-attribute/generics-default-stability.rs
new file mode 100644
index 000000000..300cc34d6
--- /dev/null
+++ b/src/test/ui/stability-attribute/generics-default-stability.rs
@@ -0,0 +1,251 @@
+// aux-build:unstable_generic_param.rs
+#![feature(unstable_default6)]
+
+extern crate unstable_generic_param;
+
+use unstable_generic_param::*;
+
+struct R;
+
+impl Trait1 for S {
+ fn foo() -> () { () } // ok
+}
+
+struct S;
+
+impl Trait3<usize> for S {
+ fn foo() -> usize { 0 } // ok
+}
+
+fn main() {
+ let _ = S;
+
+ let _: Struct1<isize> = Struct1 { field: 1 }; //~ ERROR use of unstable library feature 'unstable_default'
+
+ let _ = STRUCT1; // ok
+ let _: Struct1 = STRUCT1; // ok
+ let _: Struct1<usize> = STRUCT1; //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Struct1<isize> = Struct1 { field: 0 }; //~ ERROR use of unstable library feature 'unstable_default'
+
+ // Instability is not enforced for generic type parameters used in public fields.
+ // Note how the unstable type default `usize` leaks,
+ // and can be used without the 'unstable_default' feature.
+ let _ = STRUCT1.field;
+ let _ = Struct1 { field: 1 };
+ let _ = Struct1 { field: () };
+ let _ = Struct1 { field: 1isize };
+ let _: Struct1 = Struct1 { field: 1 };
+ let _: usize = STRUCT1.field;
+ let _ = STRUCT1.field + 1;
+ let _ = STRUCT1.field + 1usize;
+
+ let _ = Struct2 { field: 1 }; // ok
+ let _: Struct2 = Struct2 { field: 1 }; // ok
+ let _: Struct2<usize> = Struct2 { field: 1 }; // ok
+
+ let _ = STRUCT2;
+ let _: Struct2 = STRUCT2; // ok
+ let _: Struct2<usize> = STRUCT2; // ok
+ let _: Struct2<isize> = Struct2 { field: 0 }; // ok
+ let _ = STRUCT2.field; // ok
+ let _: usize = STRUCT2.field; // ok
+ let _ = STRUCT2.field + 1; // ok
+ let _ = STRUCT2.field + 1usize; // ok
+
+ let _ = STRUCT3;
+ let _: Struct3 = STRUCT3; // ok
+ let _: Struct3<isize, usize> = STRUCT3; //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Struct3<isize> = STRUCT3; // ok
+ let _: Struct3<isize, isize> = Struct3 { field1: 0, field2: 0 }; //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Struct3<usize, usize> = Struct3 { field1: 0, field2: 0 }; //~ ERROR use of unstable library feature 'unstable_default'
+ let _ = STRUCT3.field1; // ok
+ let _: isize = STRUCT3.field1; // ok
+ let _ = STRUCT3.field1 + 1; // ok
+ // Note the aforementioned leak.
+ let _: usize = STRUCT3.field2; // ok
+ let _: Struct3<usize> = Struct3 { field1: 0, field2: 0 }; // ok
+ let _ = STRUCT3.field2 + 1; // ok
+ let _ = STRUCT3.field2 + 1usize; // ok
+
+ let _ = STRUCT4;
+ let _: Struct4<isize> = Struct4 { field: 1 };
+ //~^ use of deprecated struct `unstable_generic_param::Struct4`: test [deprecated]
+ //~^^ use of deprecated struct `unstable_generic_param::Struct4`: test [deprecated]
+ //~^^^ use of deprecated field `unstable_generic_param::Struct4::field`: test [deprecated]
+ let _ = STRUCT4;
+ let _: Struct4 = STRUCT4; //~ use of deprecated struct `unstable_generic_param::Struct4`: test [deprecated]
+ let _: Struct4<usize> = STRUCT4; //~ use of deprecated struct `unstable_generic_param::Struct4`: test [deprecated]
+ let _: Struct4<isize> = Struct4 { field: 0 };
+ //~^ use of deprecated struct `unstable_generic_param::Struct4`: test [deprecated]
+ //~^^ use of deprecated struct `unstable_generic_param::Struct4`: test [deprecated]
+ //~^^^ use of deprecated field `unstable_generic_param::Struct4::field`: test [deprecated]
+
+ let _ = STRUCT5;
+ let _: Struct5<isize> = Struct5 { field: 1 }; //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated struct `unstable_generic_param::Struct5`: test [deprecated]
+ //~^^ use of deprecated struct `unstable_generic_param::Struct5`: test [deprecated]
+ //~^^^ use of deprecated field `unstable_generic_param::Struct5::field`: test [deprecated]
+ let _ = STRUCT5;
+ let _: Struct5 = STRUCT5; //~ use of deprecated struct `unstable_generic_param::Struct5`: test [deprecated]
+ let _: Struct5<usize> = STRUCT5; //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated struct `unstable_generic_param::Struct5`: test [deprecated]
+ let _: Struct5<isize> = Struct5 { field: 0 }; //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated struct `unstable_generic_param::Struct5`: test [deprecated]
+ //~^^ use of deprecated struct `unstable_generic_param::Struct5`: test [deprecated]
+ //~^^^ use of deprecated field `unstable_generic_param::Struct5::field`: test [deprecated]
+
+ let _: Struct6<isize> = Struct6 { field: 1 }; // ok
+ let _: Struct6<isize> = Struct6 { field: 0 }; // ok
+
+ let _: Alias1<isize> = Alias1::Some(1); //~ ERROR use of unstable library feature 'unstable_default'
+
+ let _ = ALIAS1; // ok
+ let _: Alias1 = ALIAS1; // ok
+ let _: Alias1<usize> = ALIAS1; //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Alias1<isize> = Alias1::Some(0); //~ ERROR use of unstable library feature 'unstable_default'
+
+ // Instability is not enforced for generic type parameters used in public fields.
+ // Note how the unstable type default `usize` leaks,
+ // and can be used without the 'unstable_default' feature.
+ let _ = Alias1::Some(1);
+ let _ = Alias1::Some(());
+ let _ = Alias1::Some(1isize);
+ let _: Alias1 = Alias1::Some(1);
+ let _: usize = ALIAS1.unwrap();
+ let _ = ALIAS1.unwrap() + 1;
+ let _ = ALIAS1.unwrap() + 1usize;
+
+ let _ = Alias2::Some(1); // ok
+ let _: Alias2 = Alias2::Some(1); // ok
+ let _: Alias2<usize> = Alias2::Some(1); // ok
+
+ let _ = ALIAS2;
+ let _: Alias2 = ALIAS2; // ok
+ let _: Alias2<usize> = ALIAS2; // ok
+ let _: Alias2<isize> = Alias2::Some(0); // ok
+ let _ = ALIAS2.unwrap(); // ok
+ let _: usize = ALIAS2.unwrap(); // ok
+ let _ = ALIAS2.unwrap() + 1; // ok
+ let _ = ALIAS2.unwrap() + 1usize; // ok
+
+ let _ = ALIAS3;
+ let _: Alias3 = ALIAS3; // ok
+ let _: Alias3<isize, usize> = ALIAS3; //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Alias3<isize> = ALIAS3; // ok
+ let _: Alias3<isize, isize> = Alias3::Ok(0); //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Alias3<usize, usize> = Alias3::Ok(0); //~ ERROR use of unstable library feature 'unstable_default'
+ let _ = ALIAS3.unwrap(); // ok
+ let _: isize = ALIAS3.unwrap(); // ok
+ let _ = ALIAS3.unwrap() + 1; // ok
+ // Note the aforementioned leak.
+ let _: usize = ALIAS3B.unwrap_err(); // ok
+ let _: Alias3<usize> = Alias3::Err(0); // ok
+ let _ = ALIAS3B.unwrap_err() + 1; // ok
+ let _ = ALIAS3B.unwrap_err() + 1usize; // ok
+
+ let _ = ALIAS4;
+ let _: Alias4<isize> = Alias4::Some(1);
+ //~^ use of deprecated type alias `unstable_generic_param::Alias4`: test [deprecated]
+ //~^^ use of deprecated type alias `unstable_generic_param::Alias4`: test [deprecated]
+ let _ = ALIAS4;
+ let _: Alias4 = ALIAS4; //~ use of deprecated type alias `unstable_generic_param::Alias4`: test [deprecated]
+ let _: Alias4<usize> = ALIAS4; //~ use of deprecated type alias `unstable_generic_param::Alias4`: test [deprecated]
+ let _: Alias4<isize> = Alias4::Some(0);
+ //~^ use of deprecated type alias `unstable_generic_param::Alias4`: test [deprecated]
+ //~^^ use of deprecated type alias `unstable_generic_param::Alias4`: test [deprecated]
+
+ let _ = ALIAS5;
+ let _: Alias5<isize> = Alias5::Some(1); //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated type alias `unstable_generic_param::Alias5`: test [deprecated]
+ //~^^ use of deprecated type alias `unstable_generic_param::Alias5`: test [deprecated]
+ let _ = ALIAS5;
+ let _: Alias5 = ALIAS5; //~ use of deprecated type alias `unstable_generic_param::Alias5`: test [deprecated]
+ let _: Alias5<usize> = ALIAS5; //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated type alias `unstable_generic_param::Alias5`: test [deprecated]
+ let _: Alias5<isize> = Alias5::Some(0); //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated type alias `unstable_generic_param::Alias5`: test [deprecated]
+ //~^^ use of deprecated type alias `unstable_generic_param::Alias5`: test [deprecated]
+
+ let _: Alias6<isize> = Alias6::Some(1); // ok
+ let _: Alias6<isize> = Alias6::Some(0); // ok
+
+ let _: Enum1<isize> = Enum1::Some(1); //~ ERROR use of unstable library feature 'unstable_default'
+
+ let _ = ENUM1; // ok
+ let _: Enum1 = ENUM1; // ok
+ let _: Enum1<usize> = ENUM1; //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Enum1<isize> = Enum1::Some(0); //~ ERROR use of unstable library feature 'unstable_default'
+
+ // Instability is not enforced for generic type parameters used in public fields.
+ // Note how the unstable type default `usize` leaks,
+ // and can be used without the 'unstable_default' feature.
+ let _ = Enum1::Some(1);
+ let _ = Enum1::Some(());
+ let _ = Enum1::Some(1isize);
+ let _: Enum1 = Enum1::Some(1);
+ if let Enum1::Some(x) = ENUM1 {let _: usize = x;}
+ if let Enum1::Some(x) = ENUM1 {let _ = x + 1;}
+ if let Enum1::Some(x) = ENUM1 {let _ = x + 1usize;}
+
+ let _ = Enum2::Some(1); // ok
+ let _: Enum2 = Enum2::Some(1); // ok
+ let _: Enum2<usize> = Enum2::Some(1); // ok
+
+ let _ = ENUM2;
+ let _: Enum2 = ENUM2; // ok
+ let _: Enum2<usize> = ENUM2; // ok
+ let _: Enum2<isize> = Enum2::Some(0); // ok
+ if let Enum2::Some(x) = ENUM2 {let _ = x;} // ok
+ if let Enum2::Some(x) = ENUM2 {let _: usize = x;} // ok
+ if let Enum2::Some(x) = ENUM2 {let _ = x + 1;} // ok
+ if let Enum2::Some(x) = ENUM2 {let _ = x + 1usize;} // ok
+
+ let _ = ENUM3;
+ let _: Enum3 = ENUM3; // ok
+ let _: Enum3<isize, usize> = ENUM3; //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Enum3<isize> = ENUM3; // ok
+ let _: Enum3<isize, isize> = Enum3::Ok(0); //~ ERROR use of unstable library feature 'unstable_default'
+ let _: Enum3<usize, usize> = Enum3::Ok(0); //~ ERROR use of unstable library feature 'unstable_default'
+ if let Enum3::Ok(x) = ENUM3 {let _ = x;} // ok
+ if let Enum3::Ok(x) = ENUM3 {let _: isize = x;} // ok
+ if let Enum3::Ok(x) = ENUM3 {let _ = x + 1;} // ok
+ // Note the aforementioned leak.
+ if let Enum3::Err(x) = ENUM3B {let _: usize = x;} // ok
+ let _: Enum3<usize> = Enum3::Err(0); // ok
+ if let Enum3::Err(x) = ENUM3B {let _ = x + 1;} // ok
+ if let Enum3::Err(x) = ENUM3B {let _ = x + 1usize;} // ok
+
+ let _ = ENUM4;
+ let _: Enum4<isize> = Enum4::Some(1);
+ //~^ use of deprecated tuple variant `unstable_generic_param::Enum4::Some`: test [deprecated]
+ //~^^ use of deprecated enum `unstable_generic_param::Enum4`: test [deprecated]
+ let _ = ENUM4;
+ let _: Enum4 = ENUM4; //~ use of deprecated enum `unstable_generic_param::Enum4`: test [deprecated]
+ let _: Enum4<usize> = ENUM4; //~ use of deprecated enum `unstable_generic_param::Enum4`: test [deprecated]
+ let _: Enum4<isize> = Enum4::Some(0);
+ //~^ use of deprecated tuple variant `unstable_generic_param::Enum4::Some`: test [deprecated]
+ //~^^ use of deprecated enum `unstable_generic_param::Enum4`: test [deprecated]
+
+ let _ = ENUM5;
+ let _: Enum5<isize> = Enum5::Some(1); //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated tuple variant `unstable_generic_param::Enum5::Some`: test [deprecated]
+ //~^^ use of deprecated enum `unstable_generic_param::Enum5`: test [deprecated]
+ let _ = ENUM5;
+ let _: Enum5 = ENUM5; //~ use of deprecated enum `unstable_generic_param::Enum5`: test [deprecated]
+ let _: Enum5<usize> = ENUM5; //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated enum `unstable_generic_param::Enum5`: test [deprecated]
+ let _: Enum5<isize> = Enum5::Some(0); //~ ERROR use of unstable library feature 'unstable_default'
+ //~^ use of deprecated tuple variant `unstable_generic_param::Enum5::Some`: test [deprecated]
+ //~^^ use of deprecated enum `unstable_generic_param::Enum5`: test [deprecated]
+
+ let _: Enum6<isize> = Enum6::Some(1); // ok
+ let _: Enum6<isize> = Enum6::Some(0); // ok
+
+ let _: Box1<isize, System> = Box1::new(1); //~ ERROR use of unstable library feature 'box_alloc_param'
+ let _: Box1<isize> = Box1::new(1); // ok
+
+ let _: Box2<isize, System> = Box2::new(1); // ok
+ let _: Box2<isize> = Box2::new(1); // ok
+
+ let _: Box3<isize> = Box3::new(1); // ok
+}