aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMathias Jean Johansen <mathias@mjj.io>2022-05-01 13:14:44 +0200
committerLouis Pilfold <louis@lpil.uk>2022-05-04 22:08:15 +0100
commit4453aa1d72d407818e0abf3939299611d5997eab (patch)
tree9d9c31223ff7a8162e254463eeee72b62da3555f
parent3ca141d3d2849f67f666cfa0e9d1f6416f5c89d0 (diff)
downloadgleam_stdlib-4453aa1d72d407818e0abf3939299611d5997eab.tar.gz
gleam_stdlib-4453aa1d72d407818e0abf3939299611d5997eab.zip
Add `first` function to `String`s.
-rw-r--r--src/gleam/string.gleam23
-rw-r--r--test/gleam/string_test.gleam10
2 files changed, 33 insertions, 0 deletions
diff --git a/src/gleam/string.gleam b/src/gleam/string.gleam
index fc3071f..ac7d3aa 100644
--- a/src/gleam/string.gleam
+++ b/src/gleam/string.gleam
@@ -739,3 +739,26 @@ pub fn to_option(s: String) -> Option(String) {
_ -> Some(s)
}
}
+
+/// Returns the first element in a grapheme and wraps it in an `Option(String)`.
+/// If the `String` is empty, it returns `None`. Otherwise, it returns
+/// `Some(String)`.
+///
+/// ## Examples
+///
+/// ```gleam
+/// > first("")
+/// None
+/// ```
+///
+/// ```gleam
+/// > first("icecream")
+/// Some("i")
+/// ```
+///
+pub fn first(s: String) -> Option(String) {
+ case length(s) {
+ 0 -> None
+ _ -> Some(slice(s, 0, 1))
+ }
+}
diff --git a/test/gleam/string_test.gleam b/test/gleam/string_test.gleam
index 937df50..a98a2e2 100644
--- a/test/gleam/string_test.gleam
+++ b/test/gleam/string_test.gleam
@@ -364,3 +364,13 @@ pub fn to_option_test() {
|> string.to_option
|> should.equal(Some("ok"))
}
+
+pub fn first_test() {
+ ""
+ |> string.first
+ |> should.equal(None)
+
+ "gleam"
+ |> string.first
+ |> should.equal(Some("g"))
+}