From c093b83c9c5ad3ba92e9153569be6e27476403ea Mon Sep 17 00:00:00 2001 From: Louis Pilfold Date: Sat, 9 Dec 2023 12:23:02 +0000 Subject: Functions --- lessons/src/lesson013_functions/code.gleam | 13 +++++++++++++ lessons/src/lesson013_functions/text.html | 14 ++++++++++++++ 2 files changed, 27 insertions(+) create mode 100644 lessons/src/lesson013_functions/code.gleam create mode 100644 lessons/src/lesson013_functions/text.html (limited to 'lessons/src/lesson013_functions') diff --git a/lessons/src/lesson013_functions/code.gleam b/lessons/src/lesson013_functions/code.gleam new file mode 100644 index 0000000..220e58d --- /dev/null +++ b/lessons/src/lesson013_functions/code.gleam @@ -0,0 +1,13 @@ +import gleam/io + +pub fn main() { + io.debug(double(10)) +} + +fn double(a: Int) -> Int { + multiply(a, 2) +} + +fn multiply(a: Int, b: Int) -> Int { + a * b +} diff --git a/lessons/src/lesson013_functions/text.html b/lessons/src/lesson013_functions/text.html new file mode 100644 index 0000000..32d5bed --- /dev/null +++ b/lessons/src/lesson013_functions/text.html @@ -0,0 +1,14 @@ +

+ The fn keyword is used to define new functions. +

+

+ The double and multiply functions are defined + without the pub keyword. This makes them private + functions, they can only be used within this module. If another module + attempted to use them it would result in a compiler error. +

+

+ Like with assignments, type annotations are optional for function arguments + and return values. It is considered good practice to use type annotations for + functions, for clarity and to encourage intentional and thoughtful design. +

-- cgit v1.2.3