Skip to content

Latest commit

 

History

History
90 lines (62 loc) · 3.4 KB

README.MD

File metadata and controls

90 lines (62 loc) · 3.4 KB

FP Foundation Logo

Getting Started

1. Clone the project

git clone [email protected]:fp-tower/foundations-training.git
// or
git clone https://github.com/fp-tower/foundations-training.git

2. Run the tests

sbt test

If you don't have sbt, you can find instructions here.

3. Open your favorite IDE

Open the file exercises/function/FunctionExercises.scala and check your Scala plugin is working.

If you're using IntelliJ

  1. click the green play icon next to the object FunctionApp
  2. check Hello World! is printed on the command line

SBT 101

Start the sbt shell in your terminal by running sbt.

Actions Command to run inside sbt shell
Compile exercises/compile
Run tests exercises/test
Run tests with regex exercises/testOnly *FunctionEx*
Run tests with regex v2 exercises/testOnly *FunctionEx* -- -z "selectDigits"

Synopsis

Module 1: Function

Scala is a language with first-class functions. This simple fact has a tremendous impact on how we program. In this module, we analyse the various syntax and concepts around functions in Scala. We also look at what is the functional programming subset of Scala and what are the benefits and restrictions of using it.

Objectives:

  • Getting familiar with the various function encodings in Scala (val/def, curried/uncurried, lazy/strict parameters).
  • Understand rules of type inference.
  • Learn to detect if a function satisfies the functional programming subset.

Module 2: Side Effect

Functional programming is considerably restrictive. For example, we cannot do any actions like sending an email to our users or update a record in the database. Yet, that's something we need to do in our daily job. In this section, we will discuss the workarounds functional programmers found to interact with the outside world while respecting the limitation of functional programming. In particular, we examine Thunk, IO and some initiation to concurrency.

Objectives:

  • Being able to write an entire program following functional programming principles.
  • Learn how to test IO and laziness.
  • Getting familiar with abstract API based on type parameters.

Module 3: Error Handling

There are many ways to deal with runtime errors. The easiest and most common method consists of throwing exceptions. Unfortunately, it is not compatible with the functional programming paradigm. In this module, we look at the problems caused by exceptions and the various ways we can safely encode errors in Scala.

Objectives:

  • Learn when to use Option, Try and Either.
  • Learn how to encode errors with Algebraic Data Type (ADT) and the various trade-offs.
  • Practice how to accumulate errors or fail early.

Module 4: Type

We all have the tendency to use types that are too large for our purpose. This leads to either runtime exceptions or a lot of error handling logic. In this module, we look at using Algebraic Data Types (ADT) and type parameters to constraint our programs. We will also discuss various testing strategies and the best way to use types and tests together.

Objectives:

  • Learn how to precisely encode business requirements with types.
  • Getting more familiar with Scala's type hierarchy and type parameters.