The hit package

[Tags: bsd3, library]

Provides low level git operations

[Skip to ReadMe]


Versions0.1.0, 0.2.0, 0.2.1, 0.2.2, 0.3.0, 0.4.0, 0.4.1, 0.4.2, 0.4.3, 0.5.0, 0.5.1, 0.5.2, 0.5.3, 0.5.4, 0.5.5, 0.6.0, 0.6.1, 0.6.2, 0.6.3
Change logNone available
Dependenciesattoparsec, base (==4.*), bytedump, bytestring, containers, cryptohash, directory, filepath, hashable, hashtables, HUnit, mtl, parsec (>=3), patience, QuickCheck (>=2), random, test-framework (>=0.3), test-framework-quickcheck2 (>=0.2), unix, vector, zlib, zlib-bindings (>=0.0.1) [details]
CopyrightVincent Hanquez <>
AuthorVincent Hanquez <>
MaintainerVincent Hanquez <>
Home page
Source repositoryhead: git clone git://
ExecutablesTests, Hit
UploadedThu Sep 22 21:36:54 UTC 2011 by VincentHanquez
DistributionsDebian:0.6.3, LTSHaskell:0.6.3, NixOS:0.6.3, Stackage:0.6.3
Downloads3814 total (43 in last 30 days)
0 []
StatusDocs uploaded by user
Build status unknown [no reports yet]




testBuild unit testDisabledAutomatic
executableBuild the executableDisabledAutomatic
debugAdd some debugging optionsDisabledAutomatic

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


Maintainers' corner

For package maintainers and hackage trustees

Readme for hit-0.1.0


Hit is a reimplementation of some git operations in pure haskell.

what it does do:

what is doesn't do:

The main functions for users are available from the Data.Git.Repository module.

The essential functions are:

API Example

resolving path of the README file and returning the reference to the blob :

{-# LANGUAGE OverloadedStrings #-}
import Data.Git.Repository

showPathRef commitRef = withRepo ".git" $ \git -> do
ref <- maybe (error "inexistent object at this path") id `fmap` resolvePath git commitRef ["README"]
    putStrLn ("README has the reference: " ++ show ref)

catting an object from a ref:

import Data.Git.Repository

catFile ref = withRepo ".git" $ \git -> do
obj <- maybe (error "not a valid object") id `fmap` findObjectRaw git ref True
    L.putStrLn (oiData obj)

more examples on how to use api can be found in Hit.hs.