Skip to content

Instantly share code, notes, and snippets.

View Cursor.purs
module CSS.Cursor where
import Prelude
import CSS (CSS)
import CSS.Property (class Val, Value)
import CSS.String (fromString)
import CSS.Stylesheet (key)
newtype Cursor = Cursor Value
cscalfani / BookCover.purs
Last active Nov 10, 2020
Book Cover for Halogen App
View BookCover.purs
module Image.BookCover where
bookCover :: String
bookCover = "
View chalkStylesExports.purs
module ChalkStyles
, black
, red
, green
, yellow
, blue
, magenta
, cyan
View chalkStyles.purs
module ChalkStyles where
newtype Style = Style String
black :: Style
black = Style "black"
red :: Style
red = Style "red"
View echo-server.js
const http = require("http");
const hostname = "";
const port = 3000;
const server = http.createServer((req, res) => {
console.log(`\n${req.method} ${req.url}`);
const reverseArray = a => {
View Main.purs
module Main where
import Prelude
import Control.Monad.Except.Trans (ExceptT, runExceptT, throwError, catchError)
import Control.Monad.State.Trans (StateT, runStateT, get, put)
import Control.Monad.Writer.Trans (class MonadTell, WriterT, runWriterT, tell)
import Data.Either (Either)
import Data.Tuple (Tuple)
import Effect.Console as Console
cscalfani / ElmVSPurescript.pdf
Last active Aug 27, 2021
Here are the slides to the first lecture in my training class I'm running at work for the Elm programmers to help them transition to PureScript.
View ElmVSPurescript.pdf
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

How to Think About Monads 2

How to Think about Monads, starts with composition of pure functions and quickly transitioned to composition of pure functions with side-effects. If you haven't read it yet, please do. This continues where that left off.

By the end of that article, we created specialized composition functions that were equivalent to the Monadic bind.

From that article we can conclude that Monadic computations have the following properties:

  1. Functions are executed sequentially
  2. Optionally, control-flow can be short-circuited

foldr written the normal way and as the dual of unfoldr

The following code was inspired by Kwang's Haskell Blog post titled unfold and fold.

module Main where

import Prelude hiding (foldr)
import Data.Function ((&))