name:                 storable-record
version:              0.0.7
visibility:           public
id:                   storable-record-0.0.7-GPgmRtXBm5fEq9RAlJapmn
key:                  storable-record-0.0.7-GPgmRtXBm5fEq9RAlJapmn
license:              BSD-3-Clause
maintainer:           Henning Thielemann <storable@henning-thielemann.de>
author:               Henning Thielemann <storable@henning-thielemann.de>
stability:            Experimental
homepage:             http://code.haskell.org/~thielema/storable-record/
synopsis:             Elegant definition of Storable instances for records
description:
    With this package
    you can build a Storable instance of a record type
    from Storable instances of its elements in an elegant way.
    It does not do any magic,
    just a bit arithmetic to compute the right offsets,
    that would be otherwise done manually
    or by a preprocessor like C2HS.
    I cannot promise that the generated memory layout
    is compatible with that of a corresponding C struct.
    However, the module generates the smallest layout
    that is possible with respect to the alignment of the record elements.
    If you encounter, that a record does not have a compatible layout,
    we should fix that.
    But also without C compatibility this package is useful
    e.g. in connection with StorableVector.

    We provide Storable instance support for several cases:

    * If you wrap a type in a @newtype@,
    then you can lift its 'Storable' instance to that @newtype@
    with the module "Foreign.Storable.Newtype".
    This way you do not need the @GeneralizedNewtypeDeriving@ feature of GHC.

    * If you have a type that is an instance of 'Traversable',
    you can use that feature for implementation of 'Storable' methods.
    The module "Foreign.Storable.Traversable"
    allows manipulation of the portion of your type,
    that is accessible by 'Traversable' methods.
    For instance with the type
    @data T a = Cons Int [a]@
    and an according 'Traversable' implementation,
    you can load and store the elements of the contained list.
    This may be part of a 'Storable' implementation of the whole type.

    * If you have a record containing elements of various types,
    then you need module "Foreign.Storable.Record".

    Note however that the Storable instances
    defined with this package are quite slow in (up to) GHC-6.12.1.
    I'm afraid this is due to incomplete inlining,
    but we have still to investigate the problem.

    For examples see packages @storable-tuple@ and @sample-frame@.

category:             Data, Foreign
abi:                  a1fdd8ec488988a3ebbe59c6924c13f3
exposed:              True
exposed-modules:
    Foreign.Storable.FixedArray Foreign.Storable.Newtype
    Foreign.Storable.Record Foreign.Storable.Record.Tuple
    Foreign.Storable.Traversable

hidden-modules:
    Foreign.Storable.RecordMinimalSize Foreign.Storable.RecordReaderPtr
    Foreign.Storable.TraversableUnequalSizes

import-dirs:
    /usr/pkg/lib/aarch64-netbsd-ghc-9.10.1/storable-record-0.0.7-GPgmRtXBm5fEq9RAlJapmn

library-dirs:
    /usr/pkg/lib/aarch64-netbsd-ghc-9.10.1/storable-record-0.0.7-GPgmRtXBm5fEq9RAlJapmn

library-dirs-static:
    /usr/pkg/lib/aarch64-netbsd-ghc-9.10.1/storable-record-0.0.7-GPgmRtXBm5fEq9RAlJapmn

dynamic-library-dirs: /usr/pkg/lib/aarch64-netbsd-ghc-9.10.1
data-dir:
    /usr/pkg/share/aarch64-netbsd-ghc-9.10.1/storable-record-0.0.7

hs-libraries:         HSstorable-record-0.0.7-GPgmRtXBm5fEq9RAlJapmn
depends:
    QuickCheck-2.15.0.1-FeemO1Y9tdxDayRiDa0Qxe base-4.20.0.0-inplace
    semigroups-0.20-IxtBaDOs8gn7oLFefDRZPm transformers-0.6.1.1-inplace
    utility-ht-0.0.17.2-I22SIGO7IL89K6WUZQKLrB

haddock-interfaces:
    /usr/pkg/share/doc/aarch64-netbsd-ghc-9.10.1/storable-record-0.0.7/html/storable-record.haddock

haddock-html:
    /usr/pkg/share/doc/aarch64-netbsd-ghc-9.10.1/storable-record-0.0.7/html
