File ghc-strict-base-types.spec of Package ghc-strict-base-types
#
# spec file for package ghc-strict-base-types
#
# Copyright (c) 2017 SUSE LINUX GmbH, Nuernberg, Germany.
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
# Please submit bugfixes or comments via http://bugs.opensuse.org/
#
%global pkg_name strict-base-types
Name: ghc-%{pkg_name}
Version: 0.5.0
Release: 0
Summary: Strict variants of the types provided in base
License: BSD-3-Clause
Group: Development/Libraries/Haskell
URL: https://hackage.haskell.org/package/%{pkg_name}
Source0: https://hackage.haskell.org/package/%{pkg_name}-%{version}/%{pkg_name}-%{version}.tar.gz
BuildRequires: ghc-Cabal-devel
BuildRequires: ghc-QuickCheck-devel
BuildRequires: ghc-aeson-devel
BuildRequires: ghc-bifunctors-devel
BuildRequires: ghc-binary-devel
BuildRequires: ghc-deepseq-devel
BuildRequires: ghc-hashable-devel
BuildRequires: ghc-lens-devel
BuildRequires: ghc-rpm-macros
BuildRequires: ghc-strict-devel
%description
It is common knowledge that lazy datastructures can lead to space-leaks.
This problem is particularly prominent, when using lazy datastructures to store
the state of a long-running application in memory. The easiest solution to this
problem is to use fully strict types to store such state values. By "fully
strict types" we mean types for whose values it holds that, if they are in
weak-head normal form, then they are also in normal form. Intuitively, this
means that values of fully strict types cannot contain unevaluated thunks.
To define a fully strict datatype, one typically uses the following recipe.
1. Make all fields of every constructor strict; i.e., add a bang to all fields.
2. Use only strict types for the fields of the constructors.
The second requirement is problematic as it rules out the use of the standard
Haskell 'Maybe', 'Either', and pair types. This library solves this problem by
providing strict variants of these types and their corresponding standard
support functions and type-class instances.
Note that this library does currently not provide fully strict lists.
They can be added if they are really required. However, in many cases one
probably wants to use unboxed or strict boxed vectors from the 'vector' library
(<http://hackage.haskell.org/package/vector>) instead of strict lists.
Moreover, instead of 'String's one probably wants to use strict 'Text' values
from the 'text' library (<http://hackage.haskell.org/package/text>).
This library comes with batteries included; i.e., missing instances for
type-classes from the 'deepseq', 'binary', 'aeson', 'QuickCheck', and 'lens'
packages are included. Of particluar interest is the 'Strict' type-class
provided by the lens library
(<http://hackage.haskell.org/packages/archive/lens/3.9.0.2/doc/html/Control-Lens-Iso.html#t:Strict>).
It is used in the following example to simplify the modification of strict
fields.
> (-# LANGUAGE TemplateHaskell #-) -- replace with curly braces, > (-# LANGUAGE
OverloadedStrings #-) -- the Haddock prologues are a P.I.T.A! > > import
Control.Lens ( (.=), Strict(strict), from, Iso', makeLenses) > import
Control.Monad.State.Strict (State) > import qualified Data.Map as M > import
qualified Data.Maybe.Strict as S > import qualified Data.Text as T > > -- | An
example of a state record as it could be used in a (very minimal) > --
role-playing game. > data GameState = GameState > ( _gsCooldown :: !(S.Maybe
Int) > , _gsHealth :: !Int > ) -- replace with curly braces, *grmbl* > >
makeLenses ''GameState > > -- The isomorphism, which converts a strict field to
its lazy variant > lazy :: Strict lazy strict => Iso' strict lazy > lazy = from
strict > > type Game = State GameState > > cast :: T.Text -> Game () > cast
spell = > gsCooldown.lazy .= M.lookup spell spellDuration > -- ...
implement remainder of spell-casting ... > where > spellDuration = M.fromList
[("fireball", 5)]
See
<http://www.haskellforall.com/2013/05/program-imperatively-using-haskell.html>
for a gentle introduction to lenses and state manipulation.
Note that this package uses the types provided by the 'strict' package
(<http://hackage.haskell.org/package/strict>), but organizes them a bit
differently. More precisely, the 'strict-base-types' package
- only provides the fully strict variants of types from 'base',
- is in-sync with the current base library (base-4.6),
- provides the missing instances for (future) Haskell platform packages, and
- conforms to the standard policy that strictness variants of an existing
datatype are identified by suffixing 'Strict' or 'Lazy' in the module
hierarchy.
%package devel
Summary: Haskell %{pkg_name} library development files
Group: Development/Libraries/Haskell
Requires: %{name} = %{version}-%{release}
Requires: ghc-compiler = %{ghc_version}
Requires(post): ghc-compiler = %{ghc_version}
Requires(postun): ghc-compiler = %{ghc_version}
%description devel
This package provides the Haskell %{pkg_name} library development
files.
%prep
%setup -q -n %{pkg_name}-%{version}
%build
%ghc_lib_build
%install
%ghc_lib_install
%post devel
%ghc_pkg_recache
%postun devel
%ghc_pkg_recache
%files -f %{name}.files
%doc LICENSE
%files devel -f %{name}-devel.files
%doc CHANGES
%changelog