-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
70f06d4
commit 55d45e7
Showing
8 changed files
with
297 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
*.beam | ||
*.ez | ||
build | ||
erl_crash.dump |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
# Help | ||
|
||
## Running the tests | ||
|
||
To run the tests, run the command `gleam test` from within the exercise directory. | ||
|
||
## Submitting your solution | ||
|
||
You can submit your solution using the `exercism submit src/bettys_bike_shop.gleam` command. | ||
This command will upload your solution to the Exercism website and print the solution page's URL. | ||
|
||
It's possible to submit an incomplete solution which allows you to: | ||
|
||
- See how others have completed the exercise | ||
- Request help from a mentor | ||
|
||
## Need to get help? | ||
|
||
If you'd like help solving the exercise, check the following pages: | ||
|
||
- The [Gleam track's documentation](https://exercism.org/docs/tracks/gleam) | ||
- The [Gleam track's programming category on the forum](https://forum.exercism.org/c/programming/gleam) | ||
- [Exercism's programming category on the forum](https://forum.exercism.org/c/programming/5) | ||
- The [Frequently Asked Questions](https://exercism.org/docs/using/faqs) | ||
|
||
Should those resources not suffice, you could submit your (incomplete) solution to request mentoring. | ||
|
||
To get help if you're having trouble, you can use one of the following resources: | ||
|
||
- [gleam.run](https://gleam.run/documentation/) is the gleam official documentation. | ||
- [Discord](https://discord.gg/Fm8Pwmy) is the discord channel. | ||
- [StackOverflow](https://stackoverflow.com/questions/tagged/gleam) can be used to search for your problem and see if it has been answered already. You can also ask and answer questions. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# Hints | ||
|
||
## General | ||
|
||
- Int and float operators are described in [the language tour][tour]. | ||
- Functions for working with ints are defined in the [`gleam/int` module][int]. | ||
- Functions for working with floats are defined in the [`gleam/float` module][float]. | ||
- Functions for working with strings are defined in the [`gleam/string` module][string]. | ||
|
||
[tour]: https://gleam.run/book/tour/ints-and-floats.html | ||
[int]: https://hexdocs.pm/gleam_stdlib/gleam/int.html | ||
[float]: https://hexdocs.pm/gleam_stdlib/gleam/float.html | ||
[string]: https://hexdocs.pm/gleam_stdlib/gleam/string.html |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,175 @@ | ||
# Betty's Bike Shop | ||
|
||
Welcome to Betty's Bike Shop on Exercism's Gleam Track. | ||
If you need help running the tests or submitting your code, check out `HELP.md`. | ||
If you get stuck on the exercise, check out `HINTS.md`, but try and solve it without using those first :) | ||
|
||
## Introduction | ||
|
||
## Ints | ||
|
||
There are two different kinds of numbers in Gleam - ints and floats. | ||
|
||
Ints are whole numbers. | ||
|
||
```gleam | ||
let integer = 3 | ||
// -> 3 | ||
``` | ||
|
||
Gleam has several operators that work with ints. | ||
|
||
```gleam | ||
1 + 1 // -> 2 | ||
5 - 1 // -> 4 | ||
5 / 2 // -> 2 | ||
3 * 3 // -> 9 | ||
5 % 2 // -> 1 | ||
2 > 1 // -> True | ||
2 < 1 // -> False | ||
2 >= 1 // -> True | ||
2 <= 1 // -> False | ||
``` | ||
|
||
## Floats | ||
|
||
Floats are numbers with one or more digits behind the decimal separator. | ||
|
||
```gleam | ||
let float = 3.45 | ||
// -> 3.45 | ||
``` | ||
|
||
Floats also have their own set of operators. | ||
|
||
```gleam | ||
1.0 +. 1.4 // -> 2.4 | ||
5.0 -. 1.5 // -> 3.5 | ||
5.0 /. 2.0 // -> 2.5 | ||
3.0 *. 3.1 // -> 9.3 | ||
2.0 >. 1.0 // -> True | ||
2.0 <. 1.0 // -> False | ||
2.0 >=. 1.0 // -> True | ||
2.0 <=. 1.0 // -> False | ||
``` | ||
|
||
## Modules | ||
|
||
### Modules | ||
|
||
Gleam code is organised into modules, and each file is one Gleam module. | ||
|
||
Up until now we have written functions with the `pub fn` syntax, which defines a function that is publicly available to other modules. Functions defined with `fn` are private to the module they are defined in and cannot be used by other modules. | ||
|
||
```gleam | ||
// This function is public | ||
pub fn add(x, y) { | ||
x + y | ||
} | ||
// This function is private | ||
fn subtract(x, y) { | ||
x - y | ||
} | ||
``` | ||
|
||
Gleam modules have names, and the name is based on their file path within the `src` or `test` directory. | ||
|
||
For example, a module defined in `src\geometry\rectangle.gleam` (on Windows) or `src/geometry/rectangle.gleam` (on UNIX-like operating systems) would be named `geometry/rectangle`. | ||
|
||
### Importing functions from other modules | ||
|
||
Accessing functions defined in other modules is done via imports. | ||
All functions within that module that were exposed by it are made accessible when importing that module. | ||
But how they are accessed varies depending on how the module is imported. | ||
|
||
Qualified imports are the default, and accessing a function within such module (for example the `map` function in the `gleam/list` module) is done by prefixing the module name (`list.map`). | ||
|
||
```gleam | ||
// Import the int module | ||
import gleam/int | ||
pub fn run(x: Int) -> String { | ||
// Use the to_string function from the int module | ||
int.to_string(x) | ||
} | ||
``` | ||
|
||
By default the name used to refer to the module is the last part of the module name, in this case `int`, but this can be changed by using the `as` keyword. | ||
|
||
```gleam | ||
// Import the int module and refer to it as i | ||
import gleam/int as i | ||
pub fn run(x: Int) -> String { | ||
i.to_string(x) | ||
} | ||
``` | ||
|
||
Unqualified imports enable direct access to the exposed functions within that module, without prefixing. | ||
|
||
```gleam | ||
// Import the to_string function from the int module | ||
import gleam/int.{to_string} | ||
pub fn run(x: Int) -> String { | ||
to_string(x) | ||
} | ||
``` | ||
|
||
Qualified imports are preferred as they make it clearer to the reader where a function comes from, and to avoid name clashes. | ||
|
||
|
||
### Standard library | ||
|
||
Gleam has a rich and well-documented standard library. The documentation is available online at [hexdocs.pm/gleam_stdlib][docs]. Save this link somewhere - you will use it a lot! | ||
|
||
Most built-in data types have a corresponding module that offers functions for working with that data type, e.g. there's the `gleam/int` module for ints, `gleam/string` module for strings, `gleam/list` module for lists and so on. | ||
|
||
[docs]: https://hexdocs.pm/gleam_stdlib/ | ||
|
||
## Instructions | ||
|
||
In this exercise you're going to write some code to help Betty's Bike Shop, an online shop for bikes and parts. | ||
You have three tasks, aiming at correctly displaying the bikes and parts prices on the website. | ||
|
||
## 1. Export the `pence_to_pounds` function | ||
|
||
Your colleague has already written the skeleton of the module, the incomplete functions `pence_to_pounds` and `pounds_to_pence`. | ||
However, they have forgotten to export the `pence_to_pounds` function, so it is currently not visible by other modules or by the test suite. | ||
|
||
Export the `pence_to_pounds` function. | ||
|
||
## 2. Convert pence to pounds | ||
|
||
Currently, the price is stored as an integer number of *pence* (the bike shop is based in the UK). | ||
On the website, we want to show the price in *pounds*, where 1.00 pound amounts to 100 pence. | ||
Your first task is to implement the `pence_to_pounds` function, taking an `Int` amount of pence, and converting it into its equivalent pounds as a `Float`. | ||
You should also add type annotations for that function. | ||
|
||
```gleam | ||
pence_to_pounds(106) | ||
// -> 1.06 | ||
``` | ||
|
||
## 3. Format the price for display on the website | ||
|
||
Since Betty's bikes are sold in pounds, prices should be displayed with the symbol "£". | ||
Your second task is thus to implement the `pounds_to_string` function, taking an amount of pounds as a `Float` and returning its price displayed as a `String` with the pound symbol prepended. | ||
|
||
You should import the `gleam/float` and `gleam/string` modules before using them. | ||
|
||
You should also define the type annotation for `pounds_to_string`. | ||
|
||
```gleam | ||
pounds_to_string(1.06) | ||
// -> "£1.06" | ||
``` | ||
|
||
## Source | ||
|
||
### Created by | ||
|
||
- @lpil |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
name = "bettys_bike_shop" | ||
version = "0.1.0" | ||
|
||
[dependencies] | ||
gleam_bitwise = "~> 1.2" | ||
gleam_otp = "~> 0.7" | ||
gleam_stdlib = "~> 0.30" | ||
simplifile = "~> 0.1" | ||
|
||
[dev-dependencies] | ||
exercism_test_runner = "~> 1.4" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
# This file was generated by Gleam | ||
# You typically do not need to edit this file | ||
|
||
packages = [ | ||
{ name = "exercism_test_runner", version = "1.4.0", build_tools = ["gleam"], requirements = ["gleam_erlang", "glance", "gleam_json", "gleam_community_ansi", "gleam_stdlib", "simplifile", "gap"], otp_app = "exercism_test_runner", source = "hex", outer_checksum = "336FBF790841C2DC25EB77B35E76A09EFDB9771D7D813E0FDBC71A50CB79711D" }, | ||
{ name = "gap", version = "0.7.0", build_tools = ["gleam"], requirements = ["gleam_community_ansi", "gleam_stdlib"], otp_app = "gap", source = "hex", outer_checksum = "AF290C27B3FAE5FE64E1B7E9C70A9E29AA0F42429C0592D375770C1C51B79D36" }, | ||
{ name = "glance", version = "0.7.1", build_tools = ["gleam"], requirements = ["gleam_stdlib", "glexer"], otp_app = "glance", source = "hex", outer_checksum = "B646A08970990D9D7A103443C5CD46F9D4297BF05F188767777FCC14ADF395EA" }, | ||
{ name = "gleam_bitwise", version = "1.3.0", build_tools = ["gleam"], requirements = [], otp_app = "gleam_bitwise", source = "hex", outer_checksum = "E2A46EE42E5E9110DAD67E0F71E7358CBE54D5EC22C526DD48CBBA3223025792" }, | ||
{ name = "gleam_community_ansi", version = "1.1.0", build_tools = ["gleam"], requirements = ["gleam_stdlib", "gleam_bitwise", "gleam_community_colour"], otp_app = "gleam_community_ansi", source = "hex", outer_checksum = "6E4E0CF2B207C1A7FCD3C21AA43514D67BC7004F21F82045CDCCE6C727A14862" }, | ||
{ name = "gleam_community_colour", version = "1.1.0", build_tools = ["gleam"], requirements = ["gleam_stdlib", "gleam_bitwise"], otp_app = "gleam_community_colour", source = "hex", outer_checksum = "D27CE357ECB343929A8CEC3FBA0B499943A47F0EE1F589EE16AFC2DC21C61E5B" }, | ||
{ name = "gleam_erlang", version = "0.22.0", build_tools = ["gleam"], requirements = ["gleam_stdlib"], otp_app = "gleam_erlang", source = "hex", outer_checksum = "367D8B41A7A86809928ED1E7E55BFD0D46D7C4CF473440190F324AFA347109B4" }, | ||
{ name = "gleam_json", version = "0.6.0", build_tools = ["gleam"], requirements = ["gleam_stdlib", "thoas"], otp_app = "gleam_json", source = "hex", outer_checksum = "C6CC5BEECA525117E97D0905013AB3F8836537455645DDDD10FE31A511B195EF" }, | ||
{ name = "gleam_otp", version = "0.7.0", build_tools = ["gleam"], requirements = ["gleam_erlang", "gleam_stdlib"], otp_app = "gleam_otp", source = "hex", outer_checksum = "ED7381E90636E18F5697FD7956EECCA635A3B65538DC2BE2D91A38E61DCE8903" }, | ||
{ name = "gleam_stdlib", version = "0.31.0", build_tools = ["gleam"], requirements = [], otp_app = "gleam_stdlib", source = "hex", outer_checksum = "6D1BC5B4D4179B9FEE866B1E69FE180AC2CE485AD90047C0B32B2CA984052736" }, | ||
{ name = "glexer", version = "0.6.2", build_tools = ["gleam"], requirements = ["gleam_stdlib"], otp_app = "glexer", source = "hex", outer_checksum = "703D2347F5180B2BCEA4D258549B0D91DACD0905010892BAC46D04D913B84D1F" }, | ||
{ name = "simplifile", version = "0.1.14", build_tools = ["gleam"], requirements = ["gleam_stdlib"], otp_app = "simplifile", source = "hex", outer_checksum = "10EA0207796F20488A3A166C50A189C9385333F3C9FAC187729DE7B9CE4ADDBC" }, | ||
{ name = "thoas", version = "0.4.1", build_tools = ["rebar3"], requirements = [], otp_app = "thoas", source = "hex", outer_checksum = "4918D50026C073C4AB1388437132C77A6F6F7C8AC43C60C13758CC0ADCE2134E" }, | ||
] | ||
|
||
[requirements] | ||
exercism_test_runner = { version = "~> 1.4" } | ||
gleam_bitwise = { version = "~> 1.2" } | ||
gleam_otp = { version = "~> 0.7" } | ||
gleam_stdlib = { version = "~> 0.30" } | ||
simplifile = { version = "~> 0.1" } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
import gleam/int | ||
import gleam/float | ||
|
||
pub fn pence_to_pounds(pence: Int) -> Float { | ||
int.to_float(pence) /. 100.0 | ||
} | ||
|
||
pub fn pounds_to_string(pounds: Float) -> String { | ||
"£" <> float.to_string(pounds) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
import bettys_bike_shop | ||
import exercism/test_runner | ||
import exercism/should | ||
|
||
pub fn main() { | ||
test_runner.main() | ||
} | ||
|
||
pub fn pence_to_pounds_599_is_5_99_pounds_test() { | ||
bettys_bike_shop.pence_to_pounds(599) | ||
|> should.equal(5.99) | ||
} | ||
|
||
pub fn pence_to_pounds_33_is_0_33_pounds_test() { | ||
bettys_bike_shop.pence_to_pounds(33) | ||
|> should.equal(0.33) | ||
} | ||
|
||
pub fn pounds_to_string_5_99_test() { | ||
bettys_bike_shop.pounds_to_string(5.99) | ||
|> should.equal("£5.99") | ||
} | ||
|
||
pub fn pounds_to_string_0_33_test() { | ||
bettys_bike_shop.pounds_to_string(0.33) | ||
|> should.equal("£0.33") | ||
} |