named

Named parameters (keyword arguments) for Haskell

Version on this page:0.2.0.0@rev:2
LTS Haskell 22.39:0.3.0.1@rev:5
Stackage Nightly 2024-10-29:0.3.0.2
Latest on Hackage:0.3.0.2

See all snapshots named appears in

BSD-3-Clause licensed by Vladislav Zavialov
Maintained by Monadfix
This version can be pinned in stack with:named-0.2.0.0@sha256:8df779149e541567e34e233a83876fccaaa0f93c0e530f5e7805996720392d41,2143

Module documentation for 0.2.0.0

Depends on 1 package(full list with versions):

named is a lightweight library for named function parameters (keyword arguments) based on overloaded labels. Keyword arguments have several advantages over positional arguments:

  • they can be supplied in arbitrary order

  • their names serve as documentation at call site

  • it is impossible to accidentally mix them up

Unlike newtype wrappers, keyword arguments don't pollute the global namespace, don't require top-level definitions, and don't need to be exported.

This implementation of named parameters is typesafe, provides good type inference, descriptive type errors, and has no runtime overhead.

Example usage:

import Named

createSymLink :: "from" :! FilePath -> "to" :! FilePath -> IO ()
createSymLink (Arg from) (Arg to) = ...

main = createSymLink ! #from "/path/to/source"
                     ! #to "/target/path"

Changes

0.2.0.0

  • Removed ‘Flag’, ‘named’, ‘Apply’, ‘apply’.
  • Changed notation: ‘Named’ is now ‘(:!)’ in types, ‘Arg’ in patterns.
  • Added ‘arg’, ‘argF’.
  • Support for optional parameters: see ‘argDef’, ‘defaults’, ‘(:?)’.
  • ‘with #param value’ is now ‘with (#param value)’ to allow ‘with defaults’.
  • Internals are now exposed from “Named.Internal”.

0.1.0.0

  • First version. Released on an unsuspecting world.