diff options
author | Mathias Jean Johansen <mathias@mjj.io> | 2022-05-01 13:14:44 +0200 |
---|---|---|
committer | Louis Pilfold <louis@lpil.uk> | 2022-05-04 22:08:15 +0100 |
commit | 4453aa1d72d407818e0abf3939299611d5997eab (patch) | |
tree | 9d9c31223ff7a8162e254463eeee72b62da3555f | |
parent | 3ca141d3d2849f67f666cfa0e9d1f6416f5c89d0 (diff) | |
download | gleam_stdlib-4453aa1d72d407818e0abf3939299611d5997eab.tar.gz gleam_stdlib-4453aa1d72d407818e0abf3939299611d5997eab.zip |
Add `first` function to `String`s.
-rw-r--r-- | src/gleam/string.gleam | 23 | ||||
-rw-r--r-- | test/gleam/string_test.gleam | 10 |
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")) +} |