Much renaming and refreshing of RBE
This commit is contained in:
@@ -0,0 +1,16 @@
|
||||
static LANGUAGE: &str = "Rust";
|
||||
const THRESHOLD: i32 = 10;
|
||||
|
||||
fn is_big(n: i32) -> bool {
|
||||
n > THRESHOLD
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let n = 16;
|
||||
|
||||
println!("This is {}", LANGUAGE);
|
||||
println!("The threshold is {}", THRESHOLD);
|
||||
println!("{} is {}", n, if is_big(n) { "big" } else { "small" });
|
||||
|
||||
// THRESHOLD = 5;
|
||||
}
|
||||
@@ -0,0 +1,21 @@
|
||||
#![allow(dead_code)]
|
||||
|
||||
enum Number {
|
||||
Zero,
|
||||
One,
|
||||
Two,
|
||||
}
|
||||
|
||||
enum Color {
|
||||
Red = 0xff0000,
|
||||
Green = 0x00ff00,
|
||||
Blue = 0x0000ff,
|
||||
}
|
||||
|
||||
fn main() {
|
||||
println!("zero is {}", Number::Zero as i32);
|
||||
println!("one is {}", Number::One as i32);
|
||||
|
||||
println!("roses are #{:06x}", Color::Red as i32);
|
||||
println!("violets are #{:06x}", Color::Blue as i32);
|
||||
}
|
||||
@@ -0,0 +1,29 @@
|
||||
#![allow(dead_code)]
|
||||
|
||||
enum Status {
|
||||
Rich,
|
||||
Poor,
|
||||
}
|
||||
|
||||
enum Work {
|
||||
Civilian,
|
||||
Soldier,
|
||||
}
|
||||
|
||||
fn main() {
|
||||
use crate::Status::{Poor, Rich};
|
||||
use crate::Work::*;
|
||||
|
||||
let status = Poor;
|
||||
let work = Civilian;
|
||||
|
||||
match status {
|
||||
Rich => println!("The rich have lots of money!"),
|
||||
Poor => println!("The poor have no money..."),
|
||||
}
|
||||
|
||||
match work {
|
||||
Civilian => println!("Civilians work!"),
|
||||
Soldier => println!("Soldiers fight!"),
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,45 @@
|
||||
use crate::List::*;
|
||||
|
||||
enum List {
|
||||
Cons(u32, Box<List>),
|
||||
Nil,
|
||||
}
|
||||
|
||||
impl List {
|
||||
fn new() -> List {
|
||||
Nil
|
||||
}
|
||||
|
||||
fn prepend(self, elem: u32) -> List {
|
||||
Cons(elem, Box::new(self))
|
||||
}
|
||||
|
||||
fn len(&self) -> u32 {
|
||||
match *self {
|
||||
Cons(_, ref tail) => 1 + tail.len(),
|
||||
Nil => 0,
|
||||
}
|
||||
}
|
||||
|
||||
fn stringify(&self) -> String {
|
||||
match *self {
|
||||
Cons(head, ref tail) => {
|
||||
format!("{}, {}", head, tail.stringify())
|
||||
}
|
||||
Nil => {
|
||||
format!("Nil")
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let mut list = List::new();
|
||||
|
||||
list = list.prepend(1);
|
||||
list = list.prepend(2);
|
||||
list = list.prepend(3);
|
||||
|
||||
println!("linked list has length: {}", list.len());
|
||||
println!("{}", list.stringify());
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
enum WebEvent {
|
||||
PageLoad,
|
||||
PageUnload,
|
||||
KeyPress(char),
|
||||
Paste(String),
|
||||
Click { x: i64, y: i64 },
|
||||
}
|
||||
|
||||
fn inspect(event: WebEvent) {
|
||||
match event {
|
||||
WebEvent::PageLoad => println!("page loaded"),
|
||||
WebEvent::PageUnload => println!("page unloaded"),
|
||||
WebEvent::KeyPress(c) => println!("pressed '{}'.", c),
|
||||
WebEvent::Paste(s) => println!("pasted \"{}\".", s),
|
||||
WebEvent::Click { x, y } => {
|
||||
println!("clicked at x={}, y={}.", x, y);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let pressed = WebEvent::KeyPress('x');
|
||||
let pasted = WebEvent::Paste("my text".to_owned());
|
||||
let click = WebEvent::Click { x: 20, y: 80 };
|
||||
let load = WebEvent::PageLoad;
|
||||
let unload = WebEvent::PageUnload;
|
||||
|
||||
inspect(pressed);
|
||||
inspect(pasted);
|
||||
inspect(click);
|
||||
inspect(load);
|
||||
inspect(unload);
|
||||
}
|
||||
@@ -0,0 +1,80 @@
|
||||
#[allow(dead_code)]
|
||||
#[derive(Debug)]
|
||||
struct Person {
|
||||
name: String,
|
||||
age: u8,
|
||||
}
|
||||
|
||||
struct Unit;
|
||||
|
||||
struct Pair(i32, f32);
|
||||
|
||||
#[derive(Debug)]
|
||||
struct Point {
|
||||
x: f32,
|
||||
y: f32,
|
||||
}
|
||||
|
||||
#[derive(Debug)]
|
||||
struct Rectangle {
|
||||
top_left: Point,
|
||||
bottom_right: Point,
|
||||
}
|
||||
|
||||
fn rect_area(r: Rectangle) -> f32 {
|
||||
(r.top_left.x - r.bottom_right.x) * (r.top_left.y - r.bottom_right.y)
|
||||
}
|
||||
|
||||
fn square(p: &Point, d: f32) -> Rectangle {
|
||||
Rectangle {
|
||||
top_left: Point { x: p.x + d, y: p.y },
|
||||
bottom_right: Point { x: p.x, y: p.y + d },
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let name = String::from("Peter");
|
||||
let age = 27;
|
||||
let peter = Person { name, age };
|
||||
|
||||
println!("{:?}", peter);
|
||||
|
||||
let point: Point = Point { x: 10.3, y: 0.4 };
|
||||
|
||||
println!("point coordinates: ({}, {})", point.x, point.y);
|
||||
|
||||
let bottom_right = Point { x: 5.2, y: 0.2 };
|
||||
|
||||
println!("second point: ({}, {})", bottom_right.x, bottom_right.y);
|
||||
|
||||
let Point {
|
||||
x: left_edge,
|
||||
y: top_edge,
|
||||
} = point;
|
||||
|
||||
let rect = Rectangle {
|
||||
top_left: Point {
|
||||
x: left_edge,
|
||||
y: top_edge,
|
||||
},
|
||||
bottom_right: bottom_right,
|
||||
};
|
||||
|
||||
let _unit = Unit;
|
||||
|
||||
let pair = Pair(1, 0.1);
|
||||
|
||||
println!("pair contains {:?} and {:?}", pair.0, pair.1);
|
||||
|
||||
let Pair(integer, decimal) = pair;
|
||||
|
||||
println!("pair contains {:?} and {:?}", integer, decimal);
|
||||
|
||||
println!("rect in {:?}", rect);
|
||||
println!("area of rect is {}", rect_area(rect));
|
||||
|
||||
let lower_left = Point { x: 4.1, y: 11.3 };
|
||||
let d = 7.7f32;
|
||||
let sq = square(&lower_left, d);
|
||||
println!("sq from point={:?} of d={} is {:?}", lower_left, d, sq);
|
||||
}
|
||||
Reference in New Issue
Block a user