[Haskell-cafe] ANN: New release of regex packages

Chris Kuklewicz haskell at list.mightyreason.com
Mon Mar 5 10:51:47 EST 2007


I would like to announce new versions of the regex-* packages.  This
announcement covers:

Version Package     Description
  0.83  regex-base    -- Type Classes and generic instances
  0.90  regex-compat  -- Uses regex-posix to provide old API
  0.91  regex-dfa     -- backend, pure haskell, no submatch capture
  0.90  regex-parsec  -- backend, pure haskell
  0.91  regex-pcre    -- backend, links against libpcre
  0.91  regex-posix   -- backend, links against standard c library
  0.92  regex-tdfa    -- backend, pure haskell (Posix semantics)
  0.91  regex-tre     -- backend, links against libtre (currently buggy)

These all compile, install, and run a few test correctly.  Most
notably, I consider regex-tdfa to be of useful quality now.

Summary of changes and recommendations:
   * all packages:
   ** import Text.Regex.XXX exposes (getVersion_Text_Regex_XXX :: Data.Version)
      which allows programs to access the current version number of the package
   ** LICENSE file provided (all are 3 clause BSD except regex-dfa is LGPL)

   * regex-base:
   ** BUGFIX: one of the RegexContext instances used tail unsafely
   ** RegexMaker now has makeRegexM and makeRegexOptsM for better error handling
   ** Extract has new instances for (Seq Char) and (ByteString.Lazy),
        as well as the previous [Char] and ByteString instances

   * all backends:
   ** Now support [Char], (Seq Char), ByteString, and ByteString.Lazy
   ** CHANGE: The (=~~) monadic match operators now use makeRegexM and will call 
'fail' when a regular expression cannot be parsed.
   ** CHANGE: (import Text.Regex.BACKEND) now re-exports (module Text.Regex.Base)

   * regex-dfa:
   ** BUGFIX: No longer hangs on repeated nullable subpatterns

   * regex-tdfa:
   ** New backend in pure haskell that provides true Posix semantics
   ** Runs with excellent memory usage
   ** I recommend this backend for Posix extended regular expressions (leftmost 
longest).

   * regex-compat: No other changes, still uses regex-posix underneath, not 
recommended
   * regex-parsec: No other changes, I recommend regex-tdfa or regex-pcre instead
   * regex-pcre:   No other changes, best provider of Perl's left-biased regular 
expressions
   * regex-posix:  No other changes, very slow (on OS X the underlying C library 
is buggy)
   * regex-tre:    No other changes, underlying libtre version 0.7.5 is still buggy

Dependencies:

All of the above packages have been updated to depend on
regex-base>=0.80. I have only tested with GHC 6.6 on Mac OS X 10.4.8
(PPC, 32bit).  Porting the backends to other Haskell compilers should
be possible, though they may not support the polymorphic type class
API that regex-base provides.  Porting to GHC 6.4 should work once the
support for (Seq Char) and ByteString[.Lazy] has been edited or
externally obtained.  I think only regex-tdfa actually uses bang
patterns at the moment, and those could also be removed when porting.

Where to get more information and the packages themselves:

There is a slowly developing wiki page at
http://haskell.org/haskellwiki/Regular_expressions
for holding more documentation relating to these packages.

I have uploaded tar.gz sources for each of the packages to hackage:
http://hackage.haskell.org/packages/hackage.html
They are listed under the "Text" Category:
http://hackage.haskell.org/packages/archive/pkg-list.html#cat:Text

Development and bug fixes continue in the darcs repositories under
http://darcs.haskell.org/packages/regex-unstable/
To checkout one of the above versions with darcs you can use commands like
darcs get --partial --tag=0.83 regex-base
where the --tag=0.83 may be omitted to get the latest unstable version

To install the packages once you have the source:

For regex-pcre and regex-tre (and perhaps regex-posix) you might need
to edit the end of cabal file to provide Include and Lib directories
to the corresponding C library.

# Compile Setup.hs for better startup speed
ghc --make Setup.hs -o setup

# I use my own path and "--user" .I recommend doing this to avoid overwriting
# the global regex-* from GHC 6.6
./setup configure --enable-library-profiling --prefix=YOUR_PATH --user

./setup build

./setup install

Producing haddock documentation may not work and may not be up to
date, with the important exception of regex-base.

Future Plans:
   * regex-base: add support for generalized indices instead of the current Int
   * regex-tdfa: Improve DFA algorithm and further limit memory allocation.
                 Try to improve performance of ByteString.Lazy matching.

Cheers,
   Chris Kuklewicz


More information about the Haskell-Cafe mailing list