xcodec: Classes for working with generically typed codecs.

[ bsd3, data, library, numeric, serialization ] [ Propose Tags ] [ Report a vulnerability ]

This module provides a generic interface for working with binary codecs. It provides a type-class for manipulating bit data and instances for the bytestring package types (ByteString, ShortByteString, and LazyByteString). Another type-class is also provided for derivided type-class for importing modules to write generic encoders and decoders.


[Skip to Readme]

Flags

Manual Flags

NameDescriptionDefault
ci

CI Build options

Disabled

Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info

Downloads

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

  • No Candidates
Versions [RSS] 1.0.0.0
Change log CHANGELOG.md
Dependencies array (>=0.5 && <0.6), base (>=4.18 && <5), bytestring (>=0.12 && <0.13), containers (>=0.7 && <8), text (>=2.1 && <2.2) [details]
Tested with ghc ==9.6.7
License BSD-3-Clause
Author Zoey McBride
Maintainer zoeymcbride@mailbox.org
Uploaded by z0 at 2026-05-22T01:04:11Z
Category Numeric, Data, Serialization
Source repo head: git clone https://git.sr.ht/~z0/xcodec
Distributions
Downloads 1 total (1 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs uploaded by user
Build status unknown [no reports yet]

Readme for xcodec-1.0.0.0

[back to package description]

xcodec

The XCodec Haskell library provides a type-class for generic programming on bit data for writing encoders and decoders for codecs. The BinaryTranscoder class provides a common interface of methods for processing binary data, and default instances for the bytestring types: ByteString, ShortByteString, and LazyByteString. The StreamTranscoder class then provides the abstract methods for a generic function encoding from and a generic function decoding to the types implementing BinaryTranscoder.

Why?

XCodec exists to abstract common patterns that arise when writting code with the bytestring library in Haskell:

  • Reusing code for ShortByteString, ByteString and LazyByteString.
  • Having common interface for transfering into the bytestring Builder type.
  • Reading to and from numeric values for bitwise manipulation or initializing from constant values.

Making bytestring code generic, can also make code more memory efficient; for example, we can write functions for BinaryTranscoder and apply them to LazyByteString when reading large files and to ShortByteString when working on smaller internal structures.

Examples

Using XCodec we can easily read numeric bit data to binary formats, programmatically:

import Data.ByteString (ByteString)
import Data.ByteString.Short (ShortByteString)
import Data.ByteString.Lazy (LazyByteString)
import Data.Word (Word16)
import Data.XCodec.BinaryTranscoder (packValue)

-- Infers: packValue :: Int -> ByteString
exStrict :: ByteString
exStrict = packValue (0xdeadbeef :: Int)

-- Infers: packValue :: Integer -> LazyByteString
exLazy :: LazyByteString
exLazy = packValue (0xf000000000000000000000000000000000000000000d :: Integer)

-- Infers: packValue :: Word16 -> ShortByteString
exShort :: ShortByteString
exShort = packValue (0xcafe :: Word16)

And then serialize them through a common interface:

import Data.ByteString.Builder (toLazyByteString, string8)
import Data.XCodec.BinaryTranscoder (serializeValue)

deadbeefThreeTimes :: LazyByteString
deadbeefThreeTimes =
  toLazyByteString . mconcat $
    [ serializeValue exLazy,
      serializeValue exStrict,
      serializeValue exShort,
      string8 "Hello, World!"
    ]

It also enables extracting binary data into Integer format so that bitwise transformations can be performed on large sets of binary data in O(n) time:

import Data.Bits ((.<<.), (.&.))
import Data.Word (Word8)
import Data.XCodec.BinaryTranscoder (unpackValue)

-- Extracts the byte at the bit number (LSB=0).
byteWindowAt :: (BinaryTranscoder bxc) => bxc -> Int -> Word8
byteWindowAt bxc idx = fromIntegral $ (unpackValue bxc .>>. idx) .&. 0xFF

Licensing

The xcodec project and its modules are free software and licensed under the BSD 3-clause license. See LICENSE.txt.

Copyright © 2026 Zoey McBride | zoeymcbride@mailbox.org