2019-07-27 00:54:25 +03:00
|
|
|
|
//@ run-pass
|
|
|
|
|
|
2023-10-19 21:46:28 +00:00
|
|
|
|
#![feature(coroutines)]
|
2019-06-06 23:01:54 -04:00
|
|
|
|
|
2018-09-14 12:20:28 +02:00
|
|
|
|
#![allow(non_camel_case_types)]
|
|
|
|
|
#![allow(dead_code)]
|
2023-05-15 19:40:06 +01:00
|
|
|
|
#![allow(redundant_semicolons)]
|
2018-09-14 12:20:28 +02:00
|
|
|
|
#![allow(unreachable_code)]
|
2020-07-28 00:00:00 +00:00
|
|
|
|
#![allow(unused_braces, unused_must_use, unused_parens)]
|
2021-06-29 20:22:44 +02:00
|
|
|
|
#![allow(uncommon_codepoints, confusable_idents)]
|
2023-05-15 19:40:06 +01:00
|
|
|
|
#![allow(unused_imports)]
|
2022-11-06 01:22:31 +01:00
|
|
|
|
#![allow(unreachable_patterns)]
|
2013-10-23 04:49:18 -04:00
|
|
|
|
|
2019-01-02 21:19:03 -05:00
|
|
|
|
#![recursion_limit = "256"]
|
2018-07-05 12:07:33 +02:00
|
|
|
|
|
2023-05-15 19:40:06 +01:00
|
|
|
|
extern crate core;
|
2013-12-31 15:46:27 -08:00
|
|
|
|
use std::cell::Cell;
|
2014-02-01 04:35:36 +08:00
|
|
|
|
use std::mem::swap;
|
2023-06-19 20:22:34 -07:00
|
|
|
|
use std::ops::Deref;
|
2013-05-06 00:42:54 -04:00
|
|
|
|
|
2011-09-26 10:26:30 -07:00
|
|
|
|
// Just a grab bag of stuff that you wouldn't want to actually write.
|
2011-08-18 22:16:54 -07:00
|
|
|
|
|
2012-08-01 17:30:05 -07:00
|
|
|
|
fn strange() -> bool { let _x: bool = return true; }
|
2011-08-18 22:16:54 -07:00
|
|
|
|
|
|
|
|
|
fn funny() {
|
2011-08-19 15:16:48 -07:00
|
|
|
|
fn f(_x: ()) { }
|
2012-08-01 17:30:05 -07:00
|
|
|
|
f(return);
|
2011-08-18 22:16:54 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn what() {
|
2014-10-02 08:10:09 +03:00
|
|
|
|
fn the(x: &Cell<bool>) {
|
2013-12-31 15:46:27 -08:00
|
|
|
|
return while !x.get() { x.set(true); };
|
|
|
|
|
}
|
2014-10-02 08:10:09 +03:00
|
|
|
|
let i = &Cell::new(false);
|
2015-02-01 12:44:15 -05:00
|
|
|
|
let dont = {||the(i)};
|
2011-08-18 22:16:54 -07:00
|
|
|
|
dont();
|
2013-12-31 15:46:27 -08:00
|
|
|
|
assert!((i.get()));
|
2011-08-18 22:16:54 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn zombiejesus() {
|
2012-05-10 14:06:19 -07:00
|
|
|
|
loop {
|
2012-08-01 17:30:05 -07:00
|
|
|
|
while (return) {
|
|
|
|
|
if (return) {
|
2012-08-06 12:34:08 -07:00
|
|
|
|
match (return) {
|
2015-01-25 22:05:03 +01:00
|
|
|
|
1 => {
|
2012-08-01 17:30:05 -07:00
|
|
|
|
if (return) {
|
|
|
|
|
return
|
2012-01-29 22:58:16 -05:00
|
|
|
|
} else {
|
2012-08-01 17:30:05 -07:00
|
|
|
|
return
|
2012-01-29 22:58:16 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
2012-08-03 19:59:04 -07:00
|
|
|
|
_ => { return }
|
2012-01-29 22:58:16 -05:00
|
|
|
|
};
|
2012-08-01 17:30:05 -07:00
|
|
|
|
} else if (return) {
|
|
|
|
|
return;
|
2011-09-15 21:24:24 -07:00
|
|
|
|
}
|
|
|
|
|
}
|
2012-08-01 17:30:05 -07:00
|
|
|
|
if (return) { break; }
|
2012-05-10 14:06:19 -07:00
|
|
|
|
}
|
2011-08-18 22:16:54 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn notsure() {
|
2015-03-25 17:06:52 -07:00
|
|
|
|
let mut _x: isize;
|
2012-03-22 08:39:41 -07:00
|
|
|
|
let mut _y = (_x = 0) == (_x = 0);
|
2013-02-15 02:44:18 -08:00
|
|
|
|
let mut _z = (_x = 0) < (_x = 0);
|
2011-08-18 22:16:54 -07:00
|
|
|
|
let _a = (_x += 0) == (_x = 0);
|
2014-02-01 04:35:36 +08:00
|
|
|
|
let _b = swap(&mut _y, &mut _z) == swap(&mut _y, &mut _z);
|
2011-08-18 22:16:54 -07:00
|
|
|
|
}
|
|
|
|
|
|
2015-03-25 17:06:52 -07:00
|
|
|
|
fn canttouchthis() -> usize {
|
2013-03-22 11:23:21 -07:00
|
|
|
|
fn p() -> bool { true }
|
2013-03-28 18:39:09 -07:00
|
|
|
|
let _a = (assert!((true)) == (assert!(p())));
|
|
|
|
|
let _c = (assert!((p())) == ());
|
2015-03-03 10:42:26 +02:00
|
|
|
|
let _b: bool = (println!("{}", 0) == (return 0));
|
2011-08-18 22:16:54 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn angrydome() {
|
2012-03-09 16:11:56 -08:00
|
|
|
|
loop { if break { } }
|
2015-01-25 22:05:03 +01:00
|
|
|
|
let mut i = 0;
|
|
|
|
|
loop { i += 1; if i == 1 { match (continue) { 1 => { }, _ => panic!("wat") } }
|
2012-08-23 14:44:58 -07:00
|
|
|
|
break; }
|
2011-08-18 22:16:54 -07:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-12 16:55:36 +08:00
|
|
|
|
fn evil_lincoln() { let _evil: () = println!("lincoln"); }
|
2011-08-18 22:16:54 -07:00
|
|
|
|
|
2017-05-26 11:44:18 -04:00
|
|
|
|
fn dots() {
|
|
|
|
|
assert_eq!(String::from(".................................................."),
|
2017-06-05 21:02:55 +00:00
|
|
|
|
format!("{:?}", .. .. .. .. .. .. .. .. .. .. .. .. ..
|
|
|
|
|
.. .. .. .. .. .. .. .. .. .. .. ..));
|
2017-05-26 11:44:18 -04:00
|
|
|
|
}
|
|
|
|
|
|
2018-06-06 18:42:34 +02:00
|
|
|
|
fn u8(u8: u8) {
|
|
|
|
|
if u8 != 0u8 {
|
|
|
|
|
assert_eq!(8u8, {
|
|
|
|
|
macro_rules! u8 {
|
|
|
|
|
(u8) => {
|
|
|
|
|
mod u8 {
|
|
|
|
|
pub fn u8<'u8: 'u8 + 'u8>(u8: &'u8 u8) -> &'u8 u8 {
|
|
|
|
|
"u8";
|
|
|
|
|
u8
|
|
|
|
|
}
|
2017-05-26 11:44:18 -04:00
|
|
|
|
}
|
2018-06-06 18:42:34 +02:00
|
|
|
|
};
|
|
|
|
|
}
|
2017-06-05 21:02:55 +00:00
|
|
|
|
|
2018-06-06 18:42:34 +02:00
|
|
|
|
u8!(u8);
|
|
|
|
|
let &u8: &u8 = u8::u8(&8u8);
|
|
|
|
|
::u8(0u8);
|
|
|
|
|
u8
|
|
|
|
|
});
|
|
|
|
|
}
|
2017-05-26 11:44:18 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn fishy() {
|
2017-06-05 21:02:55 +00:00
|
|
|
|
assert_eq!(String::from("><>"),
|
|
|
|
|
String::<>::from::<>("><>").chars::<>().rev::<>().collect::<String>());
|
2017-05-26 11:44:18 -04:00
|
|
|
|
}
|
|
|
|
|
|
2017-08-04 00:53:09 -07:00
|
|
|
|
fn union() {
|
|
|
|
|
union union<'union> { union: &'union union<'union>, }
|
|
|
|
|
}
|
|
|
|
|
|
2018-05-25 16:48:55 +02:00
|
|
|
|
fn special_characters() {
|
2022-05-21 00:17:33 +02:00
|
|
|
|
let val = !((|(..):(_,_),(|__@_|__)|__)((&*"\\",'🤔')/**/,{})=={&[..=..][..];})//
|
2018-05-25 16:48:55 +02:00
|
|
|
|
;
|
|
|
|
|
assert!(!val);
|
|
|
|
|
}
|
|
|
|
|
|
2018-07-05 12:07:33 +02:00
|
|
|
|
fn punch_card() -> impl std::fmt::Debug {
|
|
|
|
|
..=..=.. .. .. .. .. .. .. .. .. .. .. ..=.. ..
|
|
|
|
|
..=.. ..=.. .. .. .. .. .. .. .. .. ..=..=..=..
|
|
|
|
|
..=.. ..=.. ..=.. ..=.. .. ..=..=.. .. ..=.. ..
|
|
|
|
|
..=..=.. .. ..=.. ..=.. ..=.. .. .. .. ..=.. ..
|
|
|
|
|
..=.. ..=.. ..=.. ..=.. .. ..=.. .. .. ..=.. ..
|
|
|
|
|
..=.. ..=.. ..=.. ..=.. .. .. ..=.. .. ..=.. ..
|
|
|
|
|
..=.. ..=.. .. ..=..=.. ..=..=.. .. .. ..=.. ..
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-31 15:20:10 +02:00
|
|
|
|
fn r#match() {
|
2023-06-12 16:55:36 +08:00
|
|
|
|
let val: () = match match match match match () {
|
2019-03-31 15:20:10 +02:00
|
|
|
|
() => ()
|
|
|
|
|
} {
|
|
|
|
|
() => ()
|
|
|
|
|
} {
|
|
|
|
|
() => ()
|
|
|
|
|
} {
|
|
|
|
|
() => ()
|
|
|
|
|
} {
|
|
|
|
|
() => ()
|
|
|
|
|
};
|
|
|
|
|
assert_eq!(val, ());
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-06 23:01:54 -04:00
|
|
|
|
fn i_yield() {
|
2024-04-11 13:15:34 +00:00
|
|
|
|
#[coroutine]
|
2019-06-06 23:01:54 -04:00
|
|
|
|
static || {
|
|
|
|
|
yield yield yield yield yield yield yield yield yield;
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-16 19:01:05 +07:00
|
|
|
|
fn match_nested_if() {
|
|
|
|
|
let val = match () {
|
|
|
|
|
() if if if if true {true} else {false} {true} else {false} {true} else {false} => true,
|
|
|
|
|
_ => false,
|
|
|
|
|
};
|
|
|
|
|
assert!(val);
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-12 10:38:03 +08:00
|
|
|
|
fn monkey_barrel() {
|
2023-06-12 16:55:36 +08:00
|
|
|
|
let val: () = ()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=()=();
|
2020-11-11 23:40:11 +08:00
|
|
|
|
assert_eq!(val, ());
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-21 00:17:33 +02:00
|
|
|
|
fn 𝚌𝚘𝚗𝚝𝚒𝚗𝚞𝚎() {
|
|
|
|
|
type 𝚕𝚘𝚘𝚙 = i32;
|
|
|
|
|
fn 𝚋𝚛𝚎𝚊𝚔() -> 𝚕𝚘𝚘𝚙 {
|
|
|
|
|
let 𝚛𝚎𝚝𝚞𝚛𝚗 = 42;
|
|
|
|
|
return 𝚛𝚎𝚝𝚞𝚛𝚗;
|
|
|
|
|
}
|
2021-06-29 20:22:44 +02:00
|
|
|
|
assert_eq!(loop {
|
|
|
|
|
break 𝚋𝚛𝚎𝚊𝚔 ();
|
2022-05-21 00:17:33 +02:00
|
|
|
|
}, 42);
|
2021-06-29 20:22:44 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-06-29 20:28:44 +02:00
|
|
|
|
fn function() {
|
|
|
|
|
struct foo;
|
2023-06-19 20:22:34 -07:00
|
|
|
|
impl Deref for foo {
|
|
|
|
|
type Target = fn() -> Self;
|
|
|
|
|
fn deref(&self) -> &Self::Target {
|
|
|
|
|
&((|| foo) as _)
|
2021-06-29 20:28:44 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
let foo = foo () ()() ()()() ()()()() ()()()()();
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-29 20:25:02 -07:00
|
|
|
|
fn bathroom_stall() {
|
|
|
|
|
let mut i = 1;
|
|
|
|
|
matches!(2, _|_|_|_|_|_ if (i+=1) != (i+=1));
|
|
|
|
|
assert_eq!(i, 13);
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-06 01:22:31 +01:00
|
|
|
|
fn closure_matching() {
|
|
|
|
|
let x = |_| Some(1);
|
|
|
|
|
let (|x| x) = match x(..) {
|
|
|
|
|
|_| Some(2) => |_| Some(3),
|
|
|
|
|
|_| _ => unreachable!(),
|
|
|
|
|
};
|
|
|
|
|
assert!(matches!(x(..), |_| Some(4)));
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-15 19:40:06 +01:00
|
|
|
|
fn semisemisemisemisemi() {
|
|
|
|
|
;;;;;;; ;;;;;;; ;;; ;;; ;;
|
|
|
|
|
;; ;; ;;;; ;;;; ;;
|
|
|
|
|
;;;;;;; ;;;;; ;; ;;;; ;; ;;
|
|
|
|
|
;; ;; ;; ;; ;; ;;
|
|
|
|
|
;;;;;;; ;;;;;;; ;; ;; ;;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn useful_syntax() {
|
|
|
|
|
use {{std::{{collections::{{HashMap}}}}}};
|
|
|
|
|
use ::{{{{core}, {std}}}};
|
|
|
|
|
use {{::{{core as core2}}}};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn infcx() {
|
|
|
|
|
pub mod cx {
|
|
|
|
|
pub mod cx {
|
|
|
|
|
pub use super::cx;
|
|
|
|
|
pub struct Cx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
let _cx: cx::cx::Cx = cx::cx::cx::cx::cx::Cx;
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-16 23:32:24 +01:00
|
|
|
|
fn return_already() -> impl std::fmt::Debug {
|
|
|
|
|
loop {
|
|
|
|
|
return !!!!!!!
|
|
|
|
|
break !!!!!!1111
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-21 13:47:45 +01:00
|
|
|
|
fn fake_macros() -> impl std::fmt::Debug {
|
2023-12-16 23:32:24 +01:00
|
|
|
|
loop {
|
|
|
|
|
if! {
|
|
|
|
|
match! (
|
|
|
|
|
break! {
|
|
|
|
|
return! {
|
|
|
|
|
1337
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
{}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
{}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-16 23:30:05 +02:00
|
|
|
|
fn fish_fight() {
|
|
|
|
|
trait Rope {
|
|
|
|
|
fn _____________<U>(_: Self, _: U) where Self: Sized {}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
struct T;
|
|
|
|
|
|
|
|
|
|
impl Rope for T {}
|
|
|
|
|
|
|
|
|
|
fn tug_o_war(_: impl Fn(T, T)) {}
|
|
|
|
|
|
|
|
|
|
tug_o_war(<T>::_____________::<T>);
|
|
|
|
|
}
|
|
|
|
|
|
2013-02-01 19:43:17 -08:00
|
|
|
|
pub fn main() {
|
2011-08-18 22:16:54 -07:00
|
|
|
|
strange();
|
|
|
|
|
funny();
|
|
|
|
|
what();
|
|
|
|
|
zombiejesus();
|
|
|
|
|
notsure();
|
|
|
|
|
canttouchthis();
|
|
|
|
|
angrydome();
|
|
|
|
|
evil_lincoln();
|
2017-05-26 11:44:18 -04:00
|
|
|
|
dots();
|
2018-06-06 18:42:34 +02:00
|
|
|
|
u8(8u8);
|
2017-05-26 11:44:18 -04:00
|
|
|
|
fishy();
|
2017-08-04 00:53:09 -07:00
|
|
|
|
union();
|
2018-05-25 16:50:59 +02:00
|
|
|
|
special_characters();
|
2018-07-05 12:07:33 +02:00
|
|
|
|
punch_card();
|
2019-03-31 15:20:10 +02:00
|
|
|
|
r#match();
|
2019-06-06 23:01:54 -04:00
|
|
|
|
i_yield();
|
2019-06-16 19:01:05 +07:00
|
|
|
|
match_nested_if();
|
2020-11-12 10:38:03 +08:00
|
|
|
|
monkey_barrel();
|
2022-05-21 00:17:33 +02:00
|
|
|
|
𝚌𝚘𝚗𝚝𝚒𝚗𝚞𝚎();
|
2021-06-29 20:28:44 +02:00
|
|
|
|
function();
|
2022-04-29 20:25:02 -07:00
|
|
|
|
bathroom_stall();
|
2022-11-06 01:22:31 +01:00
|
|
|
|
closure_matching();
|
2023-05-15 19:40:06 +01:00
|
|
|
|
semisemisemisemisemi();
|
|
|
|
|
useful_syntax();
|
|
|
|
|
infcx();
|
2023-12-16 23:32:24 +01:00
|
|
|
|
return_already();
|
2024-01-21 13:47:45 +01:00
|
|
|
|
fake_macros();
|
2024-04-16 23:30:05 +02:00
|
|
|
|
fish_fight();
|
2011-08-18 22:16:54 -07:00
|
|
|
|
}
|