summaryrefslogtreecommitdiff
path: root/ownership
diff options
context:
space:
mode:
authorAdam Carpenter <adam.carpenter@adp.com>2019-02-11 16:59:01 -0500
committerAdam Carpenter <adam.carpenter@adp.com>2019-02-11 16:59:01 -0500
commitef1bf4921ee4127d461eec03a14c9070d193345c (patch)
treeab9f4ed73fcf97656743c959ce8c9adbe2ce9924 /ownership
downloadlearning-rust-ef1bf4921ee4127d461eec03a14c9070d193345c.tar.xz
learning-rust-ef1bf4921ee4127d461eec03a14c9070d193345c.zip
Init.
Diffstat (limited to 'ownership')
-rwxr-xr-xownership/.gitignore2
-rwxr-xr-xownership/Cargo.lock4
-rwxr-xr-xownership/Cargo.toml7
-rwxr-xr-xownership/src/main.rs51
4 files changed, 64 insertions, 0 deletions
diff --git a/ownership/.gitignore b/ownership/.gitignore
new file mode 100755
index 0000000..53eaa21
--- /dev/null
+++ b/ownership/.gitignore
@@ -0,0 +1,2 @@
+/target
+**/*.rs.bk
diff --git a/ownership/Cargo.lock b/ownership/Cargo.lock
new file mode 100755
index 0000000..9e4e62d
--- /dev/null
+++ b/ownership/Cargo.lock
@@ -0,0 +1,4 @@
+[[package]]
+name = "ownership"
+version = "0.1.0"
+
diff --git a/ownership/Cargo.toml b/ownership/Cargo.toml
new file mode 100755
index 0000000..f21df45
--- /dev/null
+++ b/ownership/Cargo.toml
@@ -0,0 +1,7 @@
+[package]
+name = "ownership"
+version = "0.1.0"
+authors = ["Adam Carpenter <carpenat@ES.AD.ADP.COM>"]
+edition = "2018"
+
+[dependencies]
diff --git a/ownership/src/main.rs b/ownership/src/main.rs
new file mode 100755
index 0000000..1684f55
--- /dev/null
+++ b/ownership/src/main.rs
@@ -0,0 +1,51 @@
+fn main() {
+ //let words = String::from("hello there world");
+ //let words = "hello there world";
+ //let first = first_word(&words);
+ //let second = second_word(&words);
+ //let last = last_word(&words);
+ //println!("{}\n{}", first, last);
+ let a = [1, 2, 3, 4, 5];
+ let slice = &a[1..4];
+
+ for each in slice {
+ println!("{}", each);
+ }
+}
+
+fn first_word(s: &str) -> &str {
+ let bytes = s.as_bytes();
+
+ for (i, &item) in bytes.iter().enumerate() {
+ if item == b' ' {
+ return &s[..i];
+ }
+ }
+
+ &s
+}
+
+fn second_word(s: &str) -> &str {
+ let bytes = s.as_bytes();
+
+ for (i, &item) in bytes.iter().enumerate() {
+ if item == b' ' {
+ return &s[i + 1..];
+ }
+ }
+
+ &s
+}
+
+fn last_word(s: &str) -> &str {
+ let bytes = s.as_bytes();
+ let mut result = "";
+
+ for (i, &item) in bytes.iter().enumerate() {
+ if item == b' ' {
+ result = &s[i + 1..];
+ }
+ }
+
+ &result
+}