diff options
author | Louis Pilfold <louis@lpil.uk> | 2024-01-11 18:25:46 +0000 |
---|---|---|
committer | Louis Pilfold <louis@lpil.uk> | 2024-01-11 18:25:53 +0000 |
commit | 29da9b51c0d918b86108bdbf0f4c6e914b240283 (patch) | |
tree | afa831fdbb906c21cbc52cb89bcfc9488328eb89 /src/content/chapter5_advance_features/lesson01_use_continued | |
parent | 8283226cf4cf15480167a7d71d432a87bff0d07b (diff) | |
download | tour-29da9b51c0d918b86108bdbf0f4c6e914b240283.tar.gz tour-29da9b51c0d918b86108bdbf0f4c6e914b240283.zip |
Advanced features
Diffstat (limited to 'src/content/chapter5_advance_features/lesson01_use_continued')
-rw-r--r-- | src/content/chapter5_advance_features/lesson01_use_continued/code.gleam | 30 | ||||
-rw-r--r-- | src/content/chapter5_advance_features/lesson01_use_continued/text.html | 30 |
2 files changed, 60 insertions, 0 deletions
diff --git a/src/content/chapter5_advance_features/lesson01_use_continued/code.gleam b/src/content/chapter5_advance_features/lesson01_use_continued/code.gleam new file mode 100644 index 0000000..ac61062 --- /dev/null +++ b/src/content/chapter5_advance_features/lesson01_use_continued/code.gleam @@ -0,0 +1,30 @@ +import gleam/io +import gleam/result + +pub fn main() { + let x = { + use username <- result.try(get_usename()) + use password <- result.try(get_password()) + use greeting <- result.map(log_in(username, password)) + greeting <> ", " <> username + } + + case x { + Ok(greeting) -> io.println(greeting) + Error(error) -> io.println_error(error) + } +} + +// Here are some pretend functions for this example: + +fn get_usename() { + Ok("alice") +} + +fn get_password() { + Ok("hunter2") +} + +fn log_in(_username: String, _password: String) { + Ok("Welcome") +} diff --git a/src/content/chapter5_advance_features/lesson01_use_continued/text.html b/src/content/chapter5_advance_features/lesson01_use_continued/text.html new file mode 100644 index 0000000..e28c843 --- /dev/null +++ b/src/content/chapter5_advance_features/lesson01_use_continued/text.html @@ -0,0 +1,30 @@ +<p> + The <code>use</code> expression is syntactic sugar for a regular function call + and an anonymous function. +</p> + +<p>This code:</p> +<pre> +use a, b <- my_function +next(a) +next(b) +</pre> + +<p>Expands into this code:</p> +<pre> +my_function(fn(a, b) { + next(a) + next(b) +}) +</pre> + +<p> + To ensure that your <code>use</code> code works and is as understandable as + possible, the right-hand-side ideally should be a function call rather than a + pipeline or other expression, which is typically more difficult to read. +</p> + +<p> + <code>use</code> is an expression like everything else in Gleam, so it can be + placed within blocks. +</p> |