Merge branch 'master' into v3

Conflicts:
	debian/changelog
This commit is contained in:
Joey Hess 2011-06-30 14:55:36 -04:00
commit ee3a0551a7
9 changed files with 96 additions and 27 deletions

1
.gitignore vendored
View file

@ -16,3 +16,4 @@ html
Touch.hs Touch.hs
StatFS.hs StatFS.hs
Remote/S3.hs Remote/S3.hs
dist

View file

@ -11,6 +11,8 @@ mans=git-annex.1 git-annex-shell.1 git-union-merge.1
all: $(bins) $(mans) docs all: $(bins) $(mans) docs
sources: SysConfig.hs StatFS.hs Touch.hs Remote/S3.hs
SysConfig.hs: configure.hs TestConfig.hs SysConfig.hs: configure.hs TestConfig.hs
$(GHCMAKE) configure $(GHCMAKE) configure
./configure ./configure
@ -19,8 +21,10 @@ SysConfig.hs: configure.hs TestConfig.hs
hsc2hs $< hsc2hs $<
perl -i -pe 's/^{-# INCLUDE.*//' $@ perl -i -pe 's/^{-# INCLUDE.*//' $@
Remote/S3.o: Remote/S3.hs:
@ln -sf S3real.hs Remote/S3.hs @ln -sf S3real.hs Remote/S3.hs
Remote/S3.o: Remote/S3.hs
@if ! $(GHCMAKE) Remote/S3.hs; then \ @if ! $(GHCMAKE) Remote/S3.hs; then \
ln -sf S3stub.hs Remote/S3.hs; \ ln -sf S3stub.hs Remote/S3.hs; \
echo "** building without S3 support"; \ echo "** building without S3 support"; \

17
Setup.hs Normal file
View file

@ -0,0 +1,17 @@
{- cabal setup file -}
import Distribution.Simple
import System.Cmd
main = defaultMainWithHooks simpleUserHooks {
preConf = makeSources,
postClean = makeClean
}
makeSources _ _ = do
system "make sources"
return (Nothing, [])
makeClean _ _ _ _ = do
system "make clean"
return ()

View file

@ -56,12 +56,24 @@ unicodeFilePath = do
{- Pulls package version out of the changelog. -} {- Pulls package version out of the changelog. -}
getVersion :: Test getVersion :: Test
getVersion = do getVersion = do
changelog <- readFile "debian/changelog" changelog <- readFile "CHANGELOG"
let verline = head $ lines changelog let verline = head $ lines changelog
let version = middle (words verline !! 1) let version = middle (words verline !! 1)
-- Replace Version field in cabal file, so I don't have to maintain
-- the version there too.
cabal <- readFile cabalfile
writeFile tmpcabalfile $ unlines $ map (setversion version) $ lines cabal
renameFile tmpcabalfile cabalfile
return $ Config "packageversion" (StringConfig version) return $ Config "packageversion" (StringConfig version)
where where
middle s = drop 1 $ take (length s - 1) s middle s = drop 1 $ take (length s - 1) s
cabalfile = "git-annex.cabal"
tmpcabalfile = cabalfile++".tmp"
setversion version s
| "Version:" `isPrefixOf` s = "Version: " ++ version
| otherwise = s
setup :: IO () setup :: IO ()
setup = do setup = do

4
debian/changelog vendored
View file

@ -9,6 +9,10 @@ git-annex (3.20110625) UNRELEASED; urgency=low
* --force will cause add, etc, to operate on ignored files. * --force will cause add, etc, to operate on ignored files.
* Avoid mangling encoding when storing the description of repository * Avoid mangling encoding when storing the description of repository
and other content. and other content.
* cabal can now be used to build git-annex. This is substantially
slower than using make, does not build or install documentation,
does not run the test suite, and is not particularly recommended,
but could be useful to some.
-- Joey Hess <joeyh@debian.org> Sun, 26 Jun 2011 21:01:06 -0400 -- Joey Hess <joeyh@debian.org> Sun, 26 Jun 2011 21:01:06 -0400

View file

@ -33,3 +33,10 @@ To build and use git-annex, you will need:
* [ikiwiki](http://ikiwiki.info) (optional; used to build the docs) * [ikiwiki](http://ikiwiki.info) (optional; used to build the docs)
Then just [[download]] git-annex and run: `make; make install` Then just [[download]] git-annex and run: `make; make install`
## Using cabal
As a haskell package, git-annex can be built using cabal. For example:
cabal configure
cabal install --bindir=$HOME/bin

View file

@ -1,8 +0,0 @@
[[!comment format=mdwn
username="http://peter-simons.myopenid.com/"
ip="84.189.1.247"
subject="Why isn't this package built with Cabal?"
date="2011-03-23T11:31:06Z"
content="""
It would be a lot easier to compile this package, if it had a Cabal file to describe the build; especially the build-time dependencies. Why isn't Cabal used?
"""]]

View file

@ -1,17 +0,0 @@
[[!comment format=mdwn
username="http://joey.kitenet.net/"
nickname="joey"
subject="comment 2"
date="2011-03-23T15:18:29Z"
content="""
Because I haven't learned Cabal yet.
But also because I've had bad experiences with both a) tying a particular program to a particular language's pet build system and then having to add ugliness when I later need to do something in the build that has nothing to do with that language and b) as a user, needing to deal with the pet build systems of languages when I just need to make some small change to the build process that is trivial in a Makefile.
With that said, I do have a configure program written in Haskell, so at least it doesn't use autotools. :)
Update: I did try using cabal, but git-annex includes 3 programs, and they
all link to a lot of git-annex modules, and cabal wanted to build nearly
every module 3 times, which was too slow for me and I could not find a way
around.
"""]]

49
git-annex.cabal Normal file
View file

@ -0,0 +1,49 @@
Name: git-annex
Version: 3.20110625
Cabal-Version: >= 1.2
License: GPL
Maintainer: Joey Hess <joey@kitenet.net>
Author: Joey Hess
Stability: Stable
Copyright: 2010-2011 Joey Hess
License-File: GPL
Extra-Source-Files:
Homepage: http://git-annex.branchable.com/
Build-type: Custom
Category: Utility
Synopsis: manage files with git, without checking their contents into git
Description:
git-annex allows managing files with git, without checking the file
contents into git. While that may seem paradoxical, it is useful when
dealing with files larger than git can currently easily handle, whether due
to limitations in memory, checksumming time, or disk space.
.
Even without file content tracking, being able to manage files with git,
move files around and delete files with versioned directory trees, and use
branches and distributed clones, are all very handy reasons to use git. And
annexed files can co-exist in the same git repository with regularly
versioned files, which is convenient for maintaining documents, Makefiles,
etc that are associated with annexed files but that benefit from full
revision control.
Executable git-annex
Main-Is: git-annex.hs
GHC-Options: -O2
Build-Depends: haskell98, base, MissingH, hslogger, directory, filepath,
unix, containers, utf8-string, network, mtl, bytestring, old-locale, time,
pcre-light, extensible-exceptions, dataenc, SHA, process, hS3
Executable git-annex-shell
Main-Is: git-annex-shell.hs
GHC-Options: -O2
Build-Depends: haskell98, base, MissingH, hslogger, directory, filepath,
unix, containers, utf8-string, network, mtl, bytestring, old-locale, time,
pcre-light, extensible-exceptions, dataenc, SHA, process, hS3
Executable git-union-merge
Main-Is: git-union-merge.hs
GHC-Options: -O2
source-repository head
type: git
location: git://git-annex.branchable.com/