-
Notifications
You must be signed in to change notification settings - Fork 145
Online REPL Walkthrough
In the online REPL, you can use the editor pane on the left hand side to insert and edit Frege code.
You can then run it by clicking the 'Evaluate' button at the bottom or by pressing 'Ctrl + Enter'.
This wiki page should provide you with some ideas that you may want to try in the Repl.
Please note that at the moment any printing to stdout does not lead to visible output. Only the value of the last evaluated expression is visible.
The Read-Evaluate-Print-Loop (REPL) reads one command at a time, evaluates it, prints the result, and then waits for the next input. For editing multi-line input, it is easier to use the editor in the left panel.
Special commands that modify the behavior of the REPL start with a colon :
, most notably :help
.
You can also use the Up/Down arrow keys on your keyboard to browse through the history of previously entered commands.
The online REPL is only one of many REPL applications that Frege supports. They all share the same basic behavior and the same underlying interpreter. The basic REPL is contained in the Frege distribution, which uses it with a command-line interface and a Swing-based GUI. There also is JavaFX based REPL that uses FregeFX, and the online REPL that we talk about here.
Let's go through some typical Frege features.
Start with creating a list and assign it to the reference myList
.
frege> myList = [1,2,3]
value myList :: [Int]
The REPL tells you the type of the last evaluated expression.
Read this as myList
is of type (::
) List ([ ]
) of Integer (Int
).
Now try to assign a new value to myList
:
frege> myList = [5,6,7]
2: E .fr:2: function binding without patterns must have only a single equation
Here E
calls out an error at line 2. You are not allowed to assign new values to
existing references. Never. (We explain the error message later.)
If you changed your mind, what myList
should be, you either have to give it a new name
or reset the evaluation context:
frege> :reset
frege> myList = [5,6,7]
value myList :: [Int]
After reset, your command history is still intact but all previously known references have gone.
You can use :browse
to see the currently known references:
frege> :browse
value myList :: [Int]
frege> :reset
frege> :browse
Copy the following code in the editor and evaluate it.
This will show the :load editor
command in the repl and some evaluation result.
You can now run the run function by typing run
in the repl.
module examples.JSONExample where
import Data.JSON
data Coordinate = Coordinate { lon :: Float, lat :: Float }
derive Show Coordinate
data Weather = Weather { loc :: Coordinate
, temp :: Int
, desc :: String
, alert :: Maybe String
}
derive Show Weather
instance ToJSON Coordinate where
toJSON coord = Struct [ ("lon", toJSON coord.lon), ("lat", toJSON coord.lat) ]
instance ToJSON Weather where
toJSON Weather{loc, temp, desc, alert}
= Struct [ ("loc", toJSON loc)
, ("temp", toJSON temp)
, ("desc", toJSON desc)
, ("alert", toJSON $ fromMaybe "null" alert)
]
run = toJSON $ Weather location 98 "overcast clouds" (Just "Excessive heat")
where
location = Coordinate { lon = -122.09, lat = 37.39 }
Home
News
Community
- Online Communities
- Frege Ecosystem
- Frege Day 2015
- Protocol
- Simon Peyton-Jones Transcript
- Talks
- Articles
- Books
- Courses
Documentation
- Getting Started
- Online REPL
- FAQ
- Language and API Reference
- Libraries
- Language Interoperability
- Calling Frege From Java (old)
- Calling Java From Frege
- Calling Frege From Java (new)
- Compiler Manpage
- Source Code Doc
- Contributing
- System Properties
- License
- IDE Support
- Eclipse
- Intellij
- VS Code and Language Server
- Haskell
- Differences
- GHC Options vs Frege
- Learn You A Haskell Adaptations
- Official Doc
Downloads