Actions
Haskell » History » Revision 57
« Previous |
Revision 57/90
(diff)
| Next »
Ilya Kostyuchenko, 09/17/2019 04:54 PM
Haskell¶
Изучение¶
Денис Москвин. Функциональное программирование на языке Haskell. stepik.org, видеокурс
О Haskell по-человечески
Learn You a Haskell for Great Good!
Real World Haskell by Bryan O'Sullivan, Don Stewart, and John Goerzen
ru.haskell— сообщество русскоговорящих Haskell-разработчиков
Haskell Cheatsheet
haskell-trainings
Stack cookbook
The Haskell Phrasebook
Best practices¶
snippets¶
ghci running¶
stack ghci protesk:lib protesk:exe:example-that-uses-protesk
^^ running an executable that depends on the main lib requires listing the lib on the console!!
ghci debugging¶
:set -fbreak-on-error -fbreak-on-exception :trace machineMain :force _exception :hist :back
libs¶
- co-log
- named arguments
- refined — refinement types
type ProperFraction = Refined (And (Not (LessThan 0)) (Not (GreaterThan 1))) Double
- Data.Sequence — list with fast append on both sides
- bound: Making de Bruijn Succ Less — convenient combinators for working with "locally-nameless" terms. These can be useful when writing a type checker, evaluator, parser, or pretty printer for terms that contain binders like forall or lambda
- Workflow — computations resumable from storage (!)
- capability — effects based on DerivingVia
- SMT:
- concat (z3cat || smt example) — Compiling to categories — compiler plugin for translating normal Haskell functions (on standard types) to SMT, etc.
- SBV: SMT Based Verification — translates Haskell functions on custom symbolic types
- Testing:
- leancheck enumerative property-based testing core
- extrapolate generalize counter-examples of properties
- speculate discover properties
- fitspec refine properties by mutation
- hedgehog property
- dejafu concurrency
- type-spec: type level testing eDSL
- should-not-typecheck
- leancheck enumerative property-based testing core
- Constraints:
- HKD:
- (Reversible) Parsing:
- invertible-grammar by Eugene Smolanka, Sergey Vinokurov
- Syntax by Paweł Nowak (Pavel Christof?) @2014 USED NOW
- Unparse by Tillmann Rendel and Klaus Ostermann @2010
- Fresnel, Prism-based unified parsers and pretty printers by Fraser Tweedale @2016
- https://github.com/frasertweedale/hs-fresnel @2016-2017
- (related) new
optics
library, alternative tolens
@2019 - (related) Binary (ByteString-based) serialization by Lennart Kolmodin @2006-2019
exts¶
- Existential Quantification
- RebindableSyntax — overloading built-in operators / do notation
- NullaryTypeClasses — global implementation of one thing
- DataKinds , TypeFamilies (+ GHC.TypeLits) — type-level annotations
other¶
- https://github.com/cohomolo-gy/haskell-resources
- ST Monad for imperative algorithms
- A Rosetta Stone for Haskell Abstractions Applicative, StateT, Lens
- Is it possible to place inequality constraints on haskell type variables?
- Practical uses of the Tardis monad?: 'build a packet ... where the fixed-length lengths and offsets of some variable length data are sent out before the actual data themselves'
- Comonadic builders
- GHC.Stack — can get code position for DSL
- GHC's Specializer: Much More Than You Wanted to Know
- Type Classes and Constraints
- Demystifying MonadBaseControl
- Cont:
- Tagless Final / Overloading:
- Introduction to Tagless Final
- Tagless Final Encoding in Haskell
- Typed final (aka, ``tagless-final'') style is a general method of embedding domain-specific languages (DSL)
- Overloading lambda
- TypeFamilies:
- Functional Dependencies & Type Families
- Associated Types and Haskell
- Partially applied type families GHC Proposal
- On the arity of type families + Higher-order Type-level Programming in Haskell
- Type Class Instances for Type-Level Lambdas in Haskell
- Defunctionalization for Haskell Type Families
- Haskell with only one type family
- HKD:
Updated by Ilya Kostyuchenko over 5 years ago · 90 revisions