patch applied (ghc): Avoid the use of unversioned package dependencies

Duncan Coutts duncan.coutts at worc.ox.ac.uk
Thu Nov 15 08:02:11 EST 2007


On Thu, 2007-11-15 at 03:11 -0800, Simon Marlow wrote:
> Thu Nov 15 02:32:49 PST 2007  Simon Marlow <simonmar at microsoft.com>
>   * Avoid the use of unversioned package dependencies
>   Fortunately "ghc-pkg list $pkg --simple-output" is a good way to add
>   the version number.

You're lucky that you've only got one version of each package and no
per-user package DB. I was trying to do the same in Gtk2Hs which still
does not use Cabal and so has to find the package version itself.
Currently I have to use:

if test "$USERPKGCONF" = "yes"; then
	#select packages from all sections
        PKGS=$(${GHCPKG} list $pkg | sed -e '/package.conf:/d')
else
	#select packages from the first section only
        PKGS=$(${GHCPKG} list $pkg | sed -e '1d;/package.conf:/,$d')
fi
$PKG_VER=$(echo "${PKGS}"
	| sed -e 's/,/\n/g'		\#break into lines on ,
	      -e 's/[[(){}, ]]//g'	\#strip hidden package markers
	| grep -v '^$'			\#strip blank lines
	| sed -e 's/[[A-Za-z-]]*//'	\#select version components
	| sort -r -n			\#sort on version 'number'
	| head -n1)			\#head

Yes it is that ugly :-) (partly because it also has to work on Solaris)

It's particularly ugly because it has to work on the normal human
readable output rather than the nice --simple-output because the simple
output does not distinguish between global and user package dbs, whereas
the human readable form does.

If ghc-pkg let me select which package dbs I'm interested in then it
would be a lot simpler. If we could directly resolve a package name to
the package-name-version that would be even better. That is it should
use the same algorithm that ghc uses to resolve "-package Foo" to some
specific version of Foo (latest non-hidden one). Though again we need
control over the dbs it consults since we might be doing a global
install.

Duncan



More information about the Cvs-ghc mailing list