Compare commits
No commits in common. "afc53f5a38f9963e0a95491acf5e74817caa7366" and "e1246d346ddab55e3a3bd0596ac6d89e7decd7e9" have entirely different histories.
afc53f5a38
...
e1246d346d
15 changed files with 0 additions and 249 deletions
BIN
ch10/extract_fn
BIN
ch10/extract_fn
Binary file not shown.
|
|
@ -1,21 +0,0 @@
|
||||||
fn largest(list: &[i32]) -> &i32 {
|
|
||||||
let mut largest = &list[0];
|
|
||||||
|
|
||||||
for num in list {
|
|
||||||
if num > largest {
|
|
||||||
largest = num;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
largest
|
|
||||||
}
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
let number_list = vec![30, 52, 12, 69, 23, 50];
|
|
||||||
let large = largest(&number_list);
|
|
||||||
println!("Largest: {large}");
|
|
||||||
|
|
||||||
let number_list = vec![130, 52, 12, 69, 23, 50];
|
|
||||||
let large = largest(&number_list);
|
|
||||||
println!("Largest: {large}");
|
|
||||||
}
|
|
||||||
Binary file not shown.
|
|
@ -1,22 +0,0 @@
|
||||||
use std::io;
|
|
||||||
|
|
||||||
fn longest<'a>(x: &'a str, y: &'a str) -> &'a str {
|
|
||||||
if x.len() > y.len() { x } else { y }
|
|
||||||
}
|
|
||||||
|
|
||||||
fn brap<'b>(x: &'b str, y: &str) -> &'b str {
|
|
||||||
if x.len() > y.len() { x } else { "henkieeeeee" }
|
|
||||||
}
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
let stronk = String::from("stronkman");
|
|
||||||
|
|
||||||
let ln;
|
|
||||||
{
|
|
||||||
let stonks = "stonks";
|
|
||||||
let mut inp = String::new();
|
|
||||||
io::stdin().read_line(&mut inp).expect("Please input a name");
|
|
||||||
ln = longest(&inp, brap(stronk.as_str(), stonks));
|
|
||||||
}
|
|
||||||
println!("The longest of them all: {}", ln);
|
|
||||||
}
|
|
||||||
Binary file not shown.
|
|
@ -1,29 +0,0 @@
|
||||||
trait Named {
|
|
||||||
fn say_name(&self) -> String;
|
|
||||||
}
|
|
||||||
|
|
||||||
trait Bold {
|
|
||||||
fn write_bold(&self);
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: Named> Bold for T {
|
|
||||||
fn write_bold(&self) {
|
|
||||||
println!("!bold {}", self.say_name())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct Person {
|
|
||||||
name: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Named for Person {
|
|
||||||
fn say_name(&self) -> String {
|
|
||||||
self.name.clone()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
let p = Person{name: String::from("Jasper")};
|
|
||||||
|
|
||||||
p.write_bold();
|
|
||||||
}
|
|
||||||
7
ch11/adder/Cargo.lock
generated
7
ch11/adder/Cargo.lock
generated
|
|
@ -1,7 +0,0 @@
|
||||||
# This file is automatically @generated by Cargo.
|
|
||||||
# It is not intended for manual editing.
|
|
||||||
version = 4
|
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "adder"
|
|
||||||
version = "0.1.0"
|
|
||||||
|
|
@ -1,6 +0,0 @@
|
||||||
[package]
|
|
||||||
name = "adder"
|
|
||||||
version = "0.1.0"
|
|
||||||
edition = "2024"
|
|
||||||
|
|
||||||
[dependencies]
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
||||||
pub fn add(left: u64, right: u64) -> u64 {
|
|
||||||
left + right
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
|
||||||
struct Rectangle {
|
|
||||||
width: u32,
|
|
||||||
height: u32,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Rectangle {
|
|
||||||
fn can_hold(&self, other: &Rectangle) -> bool {
|
|
||||||
self.width >= other.width && self.height >= other.height
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(test)]
|
|
||||||
mod tests {
|
|
||||||
use super::*;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn explore() {
|
|
||||||
let result = add(2, 2);
|
|
||||||
assert_eq!(result, 4);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn another() {
|
|
||||||
panic!("Fail!")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
7
ch12-io-project/minigrep/Cargo.lock
generated
7
ch12-io-project/minigrep/Cargo.lock
generated
|
|
@ -1,7 +0,0 @@
|
||||||
# This file is automatically @generated by Cargo.
|
|
||||||
# It is not intended for manual editing.
|
|
||||||
version = 4
|
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "minigrep"
|
|
||||||
version = "0.1.0"
|
|
||||||
|
|
@ -1,6 +0,0 @@
|
||||||
[package]
|
|
||||||
name = "minigrep"
|
|
||||||
version = "0.1.0"
|
|
||||||
edition = "2024"
|
|
||||||
|
|
||||||
[dependencies]
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
To tell your name the livelong day
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
||||||
I'm nobody! Who are you?
|
|
||||||
Are you nobody, too?
|
|
||||||
Then there's a pair of us - don't tell!
|
|
||||||
They'd banish us, you know.
|
|
||||||
|
|
||||||
How dreary to be somebody!
|
|
||||||
How public, like a frog
|
|
||||||
To tell your name the livelong day
|
|
||||||
To an admiring bog!
|
|
||||||
|
|
@ -1,55 +0,0 @@
|
||||||
pub fn search<'a>(query: &str, contents: &'a str) -> Vec<&'a str> {
|
|
||||||
let mut results = Vec::new();
|
|
||||||
|
|
||||||
for line in contents.lines() {
|
|
||||||
if line.contains(query) {
|
|
||||||
results.push(line);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
results
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn search_case_insensitive<'a>(query: &str, contents: &'a str) -> Vec<&'a str> {
|
|
||||||
let mut results = Vec::new();
|
|
||||||
let query = query.to_lowercase();
|
|
||||||
|
|
||||||
for line in contents.lines() {
|
|
||||||
if line.to_lowercase().contains(&query) {
|
|
||||||
results.push(line);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
results
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(test)]
|
|
||||||
mod tests {
|
|
||||||
use super::*;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn case_sensitive() {
|
|
||||||
let query = "duct";
|
|
||||||
let contents = "\
|
|
||||||
Rust:
|
|
||||||
safe, fast, productive.
|
|
||||||
Pick three.
|
|
||||||
Duct tape.
|
|
||||||
";
|
|
||||||
|
|
||||||
assert_eq!(vec!["safe, fast, productive."], search(query, contents));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn case_insensitive() {
|
|
||||||
let query = "rUsT";
|
|
||||||
let contents = "\
|
|
||||||
Rust:
|
|
||||||
safe, fast, productive.
|
|
||||||
Pick three.
|
|
||||||
Trust me.
|
|
||||||
";
|
|
||||||
|
|
||||||
assert_eq!(vec!["Rust:", "Trust me."], search_case_insensitive(query, contents));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,55 +0,0 @@
|
||||||
use std::env;
|
|
||||||
use std::fs;
|
|
||||||
use std::process;
|
|
||||||
use std::error::Error;
|
|
||||||
|
|
||||||
use minigrep::{search, search_case_insensitive};
|
|
||||||
|
|
||||||
fn main() {
|
|
||||||
let args: Vec<String> = env::args().collect();
|
|
||||||
let config = Config::build(&args).unwrap_or_else(|err| {
|
|
||||||
eprintln!("problem parsing arguments: {}", err);
|
|
||||||
process::exit(1);
|
|
||||||
});
|
|
||||||
|
|
||||||
if let Err(e) = run(config) {
|
|
||||||
eprintln!("problem running program: {}", e);
|
|
||||||
process::exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct Config {
|
|
||||||
query: String,
|
|
||||||
file_path: String,
|
|
||||||
ignore_case: bool,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Config {
|
|
||||||
fn build(args: &[String]) -> Result<Config, &'static str> {
|
|
||||||
if args.len() < 3 {
|
|
||||||
return Err("not enough arguments");
|
|
||||||
}
|
|
||||||
|
|
||||||
let query = args[1].clone();
|
|
||||||
let file_path = args[2].clone();
|
|
||||||
let ignore_case = env::var("IGNORE_CASE").is_ok();
|
|
||||||
|
|
||||||
Ok(Config{ query, file_path, ignore_case })
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn run(config: Config) -> Result<(), Box<dyn Error>> {
|
|
||||||
let contents = fs::read_to_string(config.file_path)?;
|
|
||||||
|
|
||||||
let results = if config.ignore_case {
|
|
||||||
search_case_insensitive(&config.query, &contents)
|
|
||||||
} else {
|
|
||||||
search(&config.query, &contents)
|
|
||||||
};
|
|
||||||
|
|
||||||
for line in results {
|
|
||||||
println!("{line}");
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue