Cabal
A framework for packaging Haskell software
| Version on this page: | 3.14.1.0 | 
| LTS Haskell 24.17: | 3.12.1.0 | 
| Stackage Nightly 2025-10-26: | 3.14.1.0 | 
| Latest on Hackage: | 3.16.0.0 | 
Cabal-3.14.1.0@sha256:d24c689fd4b56cd12f8225562c00657e97c528849a2fc3d535557a83ca5f8dfc,13720Module documentation for 3.14.1.0
- Distribution- Distribution.Backpack- Distribution.Backpack.ComponentsGraph
- Distribution.Backpack.Configure
- Distribution.Backpack.ConfiguredComponent
- Distribution.Backpack.DescribeUnitId
- Distribution.Backpack.FullUnitId
- Distribution.Backpack.LinkedComponent
- Distribution.Backpack.ModSubst
- Distribution.Backpack.ModuleShape
- Distribution.Backpack.PreModuleShape
 
- Distribution.Compat- Distribution.Compat.CreatePipe
- Distribution.Compat.Directory
- Distribution.Compat.Environment
- Distribution.Compat.FilePath
- Distribution.Compat.Internal- Distribution.Compat.Internal.TempFile
 
- Distribution.Compat.Prelude
- Distribution.Compat.Process
- Distribution.Compat.ResponseFile
- Distribution.Compat.Stack
- Distribution.Compat.Time
 
- Distribution.Make
- Distribution.PackageDescription
- Distribution.ReadE
- Distribution.Simple
- Distribution.Simple.Bench
- Distribution.Simple.Build
- Distribution.Simple.BuildPaths
- Distribution.Simple.BuildTarget
- Distribution.Simple.BuildToolDepends
- Distribution.Simple.BuildWay
- Distribution.Simple.CCompiler
- Distribution.Simple.Command
- Distribution.Simple.Compiler
- Distribution.Simple.Configure
- Distribution.Simple.Errors
- Distribution.Simple.FileMonitor
- Distribution.Simple.Flag
- Distribution.Simple.GHC
- Distribution.Simple.GHCJS
- Distribution.Simple.Glob
- Distribution.Simple.Haddock
- Distribution.Simple.HaskellSuite
- Distribution.Simple.Hpc
- Distribution.Simple.Install
- Distribution.Simple.InstallDirs
- Distribution.Simple.LocalBuildInfo
- Distribution.Simple.PackageDescription
- Distribution.Simple.PackageIndex
- Distribution.Simple.PreProcess
- Distribution.Simple.Program
- Distribution.Simple.Program.Ar
- Distribution.Simple.Program.Builtin
- Distribution.Simple.Program.Db
- Distribution.Simple.Program.Find
- Distribution.Simple.Program.GHC
- Distribution.Simple.Program.HcPkg
- Distribution.Simple.Program.Hpc
- Distribution.Simple.Program.Internal
- Distribution.Simple.Program.Ld
- Distribution.Simple.Program.ResponseFile
- Distribution.Simple.Program.Run
- Distribution.Simple.Program.Script
- Distribution.Simple.Program.Strip
- Distribution.Simple.Program.Types
 
- Distribution.Simple.Register
- Distribution.Simple.Setup
- Distribution.Simple.SetupHooks
- Distribution.Simple.ShowBuildInfo
- Distribution.Simple.SrcDist
- Distribution.Simple.Test
- Distribution.Simple.UHC
- Distribution.Simple.UserHooks
- Distribution.Simple.Utils
 
- Distribution.TestSuite
- Distribution.Types- Distribution.Types.AnnotatedId
- Distribution.Types.ComponentInclude
- Distribution.Types.ComponentLocalBuildInfo
- Distribution.Types.DumpBuildInfo
- Distribution.Types.GivenComponent
- Distribution.Types.LocalBuildConfig
- Distribution.Types.LocalBuildInfo
- Distribution.Types.PackageName
- Distribution.Types.ParStrat
- Distribution.Types.TargetInfo
 
- Distribution.Utils
- Distribution.Verbosity
 
- Distribution.Backpack
The Cabal library package
See the Cabal web site for more information.
If you also want the cabal command-line program, you need the
cabal-install package in addition to this library.
More information
Please see the Cabal web site, the user guide and the API documentation. There is additional information available on the development wiki.
Bugs
Please report bugs and feature requests to Cabal’s bug tracker.
Your help
To help Cabal’s development, it is enormously helpful to know from Cabal’s users what their most pressing problems are with Cabal and Hackage. You may have a favourite Cabal bug or limitation. Look at Cabal’s bug tracker. Ensure that the problem is reported there and adequately described. Comment on the issue to report how much of a problem the bug is for you. Subscribe to the issue’s notifications to discuss requirements and keep informed on progress. For feature requests, it is helpful if there is a description of how you would expect to interact with the new feature.
Source code
You can get the master development branch using:
$ git clone https://github.com/haskell/cabal.git
Credits
See the AUTHORS file.
Authors of the original Cabal specification:
- Isaac Jones
- Simon Marlow
- Ross Patterson
- Simon Peyton Jones
- Malcolm Wallace
Changes
3.14.1.0 Hécate November 2024
3.14.0.0 Hécate September 2024
3.12.1.0 Artem Pelenitsyn June 2024
3.12.0.0 Francesco Ariis May 2024
3.10.3.0 Hécate January 2024
3.10.2.1 Hécate October 2023
3.10.2.0 Hécate August 2023
3.10.1.0 Mikolaj Konarski March 2023
3.8.1.0 Mikolaj Konarski August 2022
3.6.3.0 March 2022
3.6.2.0 Emily Pillmore October 2021
3.6.1.0 Emily Pillmore August 2021
3.6.0.0 Emily Pillmore August 2021
3.4.1.0 Emily Pillmore October 2021
3.4.0.0 Oleg Grenrus February 2021
3.2.1.0 Oleg Grenrus October 2020
- Pass cxx-optionswith-optcxxfor GHC >= 8.10
- Use process jobs when calling subprocesses
- Require custom-setup for cabal-version: 1.24and later
- Accept linux-androideabias an alias for Android
- Fix ghci being launched before other sources are built
- Require cabal-versions >=1.25 to be exact
3.2.0.0 Herbert Valerio Riedel April 2020
- Change free text Stringfields to useShortTextin package description and installed package info.
- Split Distribution.Types.FlagandDistribution.Types.ConfVarDistribution.Types.GenericPackageDescription.
- Add GHC-8.10 support, including new extensions to
Language.Haskell.Extension.
- Use more NonEmptyinstead of ordinary lists.
- Add Distribution.Utils.Structuredfor fingeprintingBinaryblobs.
- Add null,lengthandunsafeFromUTF8BStoDistribution.Utils.ShortText.
- Refactor Distribution.Utils.IODatamodule.
- Rename Distribution.Compat.MD5toDistribution.Utils.MD5.
- Add safeHead,safeTail,safeLasttoDistribution.Utils.Generic.
- Add unsnocandunsnocNEtoDistribution.Utils.Generic.
- Add Set'modifier toDistribution.Parsec.Newtypes.
- Add Distribution.Compat.Async.
3.0.2.0 Herbert Valerio Riedel April 2020
- Disallow spaces around colon :in Dependencybuild-dependssyntax (#6538).
- Make configureaccept anypkg-config --modversionoutput (#6541).
3.0.1.0 Herbert Valerio Riedel April 2020
- Add GHC-8.8 flags to normaliseGhcFlags(#6379).
- Typo fixes (#6372).
- Limit version number parts to contain at most 9 digits (#6386).
- Fix boundless sublibrary dependency parse failure (#5846).
- cabal checkverifies- cpp-optionsmore pedantically, allowing only options starting with- -Dand- -U.
- Don’t rebuild world when new ghc flags that affect how error messages are presented is specified.
- Fix dropExeExtension behaviour on Windows (#6287).
3.0.0.0 Mikhail Glushenkov August 2019
- The 3.0 migration guide gives advice on adapting Custom setup scripts to backwards-incompatible changes in this release: https://github.com/haskell/cabal/wiki/3.0-migration-guide.
- Due to #5119, the
cabal checkwarning for bounds on internal libraries has been disabled.
- Introduce set notation for ^>=and==operators (#5906).
- ‘check’ reports warnings for various ghc-*-options fields separately (#5342).
- KnownExtension: added new extensions- DerivingViaand- EmptyDataDeriving.
- Add extra-dynamic-library-flavours, to specify extra dynamic library flavours to build and install from a .cabal file.
- autoconfUserHooksnow passes- --host=$HOSTwhen cross-compiling
- Introduce multiple public libraries feature
(#5526).
- New build-depends syntax
- Add a set of library components to the Dependencydatatype
- New visibilityfield in thelibrarystanza
- New LibraryVisibilityfield inInstalledPackageInfo
- New syntax for the --dependencyCabal flag
 
- Static linking
- Add --enable-executable-staticflag for building fully static executables (GHC’s normal “statish” linking links Haskell libraries statically, but libc and system dependencies dynamically). This new flag links everything statically.
- Note you likely want to link against muslor another libc that supports fully static linking;glibchas some issues with fully static linking.
 
- Add 
- Fix corrupted config file header for non-ASCII package names (2557).
- Extend Distribution.Simple.Utils.rewriteFileExfrom ASCII to UTF-8 encoding.
- Change the arguments of Newtypeclass to better suit @DeriveAnyClass@ usage, add default implementation in terms ofcoerce/unsafeCoerce.
- Implement support for response file arguments to defaultMain* and cabal-install.
- Uniformly provide ‘Semigroup’ instances for base < 4.9viasemigroupspackage
- Implement `{cmm,asm}-{sources,options} buildinfo fields for separate compilation of C– and ASM source files (#6033).
- Setting debug-infonow implieslibrary-stripping: Falseand `executable-stripping: False) (#2702)
- Setup.hs copyand- installnow work in the presence of- data-filesthat use- **syntax (#6125).
2.4.1.1 Mikhail Glushenkov December 2018
- Fix --with-compilerfailing to locate compiler on Windows (#5753).
- Cabal can once again be built with GHC 7.8 and 7.6 (#5730).
2.4.1.0 Mikhail Glushenkov November 2018
- Warnings in autogenerated files are now silenced (#5678).
- Improved recompilation avoidance, especially when using GHC 8.6 (#5589).
- Do not error on empty packagedbs in getInstalledPackages(#5516).
2.4.0.1 Mikhail Glushenkov September 2018
- Allow arguments to be passed to Setup.hs haddockforbuild-type:configure(#5503).
2.4.0.0 Mikhail Glushenkov September 2018
- Due to #5119, the
cabal checkwarning for bounds on internal libraries has been disabled.
- Distribution.Simple.Haddocknow checks to ensure that it does not erroneously call Haddock with no target modules. (#5232, #5459).
- Add getting(less general thanto) Lens combinator,non) and an optics to access the modules in a component of aPackageDescriptionby theComponentName:componentBuildInfoandcomponentModules
- Linker ld-optionsare now passed to GHC as-optloptions (#4925).
- Add readGhcEnvironmentFileto parse GHC environment files.
- Drop support for GHC 7.4, since it is out of our support window (and has been for over a year!)
- Deprecate preSDist,sDistHook, andpostSDistin service ofnew-sdist, since they violate key invariants of the new-build ecosystem. Useautogen-modulesandbuild-tool-dependsinstead. (#5389).
- Added --repl-optionsflag toSetup replused to pass flags to the underlying repl without affecting theLocalBuildInfo(#4247, #5287)
- KnownExtension: added new extensions- BlockArguments(#5101),- NumericUnderscores(#5130,- QuantifiedConstraints, and- StarIsType.
- buildDependsis removed from- PackageDescription. It had long been uselessly hanging about as top-level build-depends already got put into per-component condition trees anyway. Now it’s finally been put out of its misery (#4383).
- Added EtatoCompilerFlavorand to known compilers.
- cabal haddocknow generates per-component documentation (#5226).
- Wildcard improvements:
- Allow **wildcards indata-files,extra-source-filesandextra-doc-files. These allow a limited form of recursive matching, and requirecabal-version: 2.4. (#5284, #3178, et al.)
- With cabal-version: 2.4, when matching a wildcard, the requirement for the full extension to match exactly has been loosened. Instead, if the wildcard’s extension is a suffix of the file’s extension, the file will be selected. For example, previouslyfoo.en.htmlwould not match*.html, andfoo.solaris.tar.gzwould not match*.tar.gz, but now both do. This may lead to files unexpectedly being included bysdist; please audit your package descriptions if you rely on this behaviour to keep sensitive data out of distributed packages (#5372, #784, #5057).
- Wildcard syntax errors (misplaced *, etc), wildcards that refer to missing directories, and wildcards that do not match anything are now all detected bycabal check.
- Wildcard (‘globbing’) functions have been moved from
Distribution.Simple.UtilstoDistribution.Simple.Globand have been refactored.
 
- Allow 
- Fixed cxx-optionsandcxx-sourcesbuildinfo fields for separate compilation of C++ source files to correctly build and link non-library components (#5309).
- Reduced warnings generated by hsc2hs and c2hs when cxx-optionsfield is present in a component.
- cabal checknow warns if- -jis used in- ghc-optionsin a Cabal file. (#5277)
- install-includesnow works as expected with foreign libraries (#5302).
- Removed support for JHC.
- Options listed in ghc-options,cc-options,ld-options,cxx-options,cpp-optionsare not deduplicated anymore (#4449).
- Deprecated cabal hscolourin favour ofcabal haddock --hyperlink-source(#5236).
- Recognize powerpc64leas architecture PPC64.
- Cabal now deduplicates more -Iand-Land flags to avoidE2BIG(#5356).
- With build-type: configure, avoid using backslashes to delimit path components on Windows and warn about other unsafe characters in the path to the source directory on all platforms (#5386).
- Distribution.PackageDescription.Check.checkPackageFilesnow accepts a- Verbosityargument.
- Added a parameter to
Distribution.Backpack.ConfiguredComponent.toConfiguredComponentin order to fix #5409.
- Partially silence abi-dependswarnings (#5465).
- Foreign libraries are now linked against the threaded RTS when the ‘ghc-options: -threaded’ flag is used (#5431).
- Pass command line arguments to hsc2hsusing response files when possible (#3122).
2.2.0.1 Mikhail Glushenkov March 2018
- Fix checkPackageFilesfor relative directories (#5206)
2.2.0.0 Mikhail Glushenkov March 2018
- The 2.2 migration guide gives advice on adapting Custom setup scripts to backwards-incompatible changes in this release: https://github.com/haskell/cabal/wiki/2.2-migration-guide.
- New Parsec-based parser for .cabalfiles is now the default. This brings memory consumption and speed improvements, as well as making new syntax extensions easier to implement.
- Support for common stanzas (#4751).
- Added elif-conditionals to .cabalsyntax (#4750).
- The package license information can now be specified using the
SPDX syntax. This requires setting cabal-versionto 2.2+ (#2547, #5050).
- Support for GHC’s numeric -g debug levels (#4673).
- Compilation with section splitting is now supported via the
--enable-split-sectionsflag (#4819)
- Fields with mandatory commas (e.g. build-depends) may now have a leading or a trailing comma (either one, not both) (#4953)
- Added virtual-modulesfield, to allow modules that are not built but registered (#4875).
- Use better defaulting for build-type; renamePackageDescription’sbuildTypefield tobuildTypeRawand introduce newbuildTypefunction (#4958)
- D.T.PackageDescription.allBuildInfonow returns all build infos, not only for buildable components (#5087).
- Removed UnknownBuildTypeconstructor fromBuildType(#5003).
- Added HexFloatLiteralstoKnownExtension.
- Cabal will no longer try to build an empty set of inputModules(#4890).
- copyComponentand- installIncludeFileswill now look for include headers in the build directory (- dist/build/...by default) as well (#4866).
- Added cxx-optionsandcxx-sourcesbuildinfo fields for separate compilation of C++ source files (#3700).
- Removed unused --allow-newer/--allow-oldersupport fromSetup configure(#4527).
- Changed FlagAssignmentto be an opaquenewtype(#4849).
- Changed rawSystemStdInOutto use proper type to represent binary and textual data; newDistribution.Utils.IODatamodule; removed obsoletestartsWithBOM,fileHasBOM,fromUTF8, andtoUTF8functions; add newtoUTF8BS/toUTF8LBSencoding functions. (#4666)
- Added a cabal checkwarning when the.cabalfile name does not match package name (#4592).
- The arprogram now receives its arguments via a response file (@file). Old behaviour can be restored with--disable-response-filesargument toconfigureorinstall(#4596).
- Added .Lensmodules, with optics for package description data types (#4701).
- Support for building with Win32 version 2.6 (#4835).
- Change compilerExtensionsandghcOptExtensionMapto containMaybe Flags, since a supported extension can lack a flag (#4443).
- Pretty-printing of .cabalfiles is slightly different due to parser changes. For an example, see https://mail.haskell.org/pipermail/cabal-devel/2017-December/010414.html.
- --hyperlink-sourcenow uses Haddock’s hyperlinker backend when Haddock is new enough, falling back to HsColour otherwise.
- D.S.defaultHookedPackageDeschas been deprecated in favour of- D.S.findHookedPackageDesc(#4874).
- D.S.getHookedBuildInfonow takes an additional parameter specifying the build directory path (#4874).
- Emit warning when encountering unknown GHC versions (#415).
2.0.1.1 Mikhail Glushenkov December 2017
- Don’t pass other-modulesto stub executable for detailed-0.9 (#4918).
- Hpc: Use relative .mix search paths (#4917).
2.0.1.0 Mikhail Glushenkov November 2017
- Support for GHC’s numeric -g debug levels (#4673).
- Added a new Distribution.Verbosity.modifyVerbositycombinator (#4724).
- Added a new cabal checkwarning about unused, undeclared or non-Unicode flags. Also, it warns about leading dash, which is unusable but accepted if it’s unused in conditionals. (#4687)
- Modify allBuildInfoto include foreign library info (#4763).
- Documentation fixes.
2.0.0.2 Mikhail Glushenkov July 2017
- See http://coldwa.st/e/blog/2017-09-09-Cabal-2-0.html for more detailed release notes.
- The 2.0 migration guide gives advice on adapting Custom setup scripts to backwards-incompatible changes in this release: https://github.com/haskell/cabal/wiki/2.0-migration-guide
- Add CURRENT_PACKAGE_VERSION to cabal_macros.h (#4319)
- Dropped support for versions of GHC earlier than 6.12 (#3111).
- GHC compatibility window for the Cabal library has been extended to five years (#3838).
- Convenience/internal libraries are now supported (#269).
An internal library is declared using the stanza library 'libname'. Packages which use internal libraries can result in multiple registrations; thus--gen-pkg-configcan now output a directory of registration scripts rather than a single file.
- Backwards incompatible change to preprocessor interface:
the function in PPSuffixHandlernow takes an additionalComponentLocalBuildInfospecifying the build information of the component being preprocessed.
- Backwards incompatible change to cabal_macros.h(#1893): we now generate a macro file for each component which contains only information about the direct dependencies of that component. Consequently,dist/build/autogen/cabal_macros.hcontains only the macros for the library, and is not generated if a package has no library; to find the macros for an executable namedfoobar, look indist/build/foobar/autogen/cabal_macros.h. Similarly, if you usedautogenModulesDiryou should now useautogenComponentModulesDir, which now requires aComponentLocalBuildInfoargument as well in order to disambiguate which component the autogenerated files are for.
- Backwards incompatible change to Component:TestSuiteandBenchmarkno longer havetestEnabledandbenchmarkEnabled. If you usedenabledTestsorenabledBenchmarks, please instead useenabledTestLBIsandenabledBenchLBIs(you will need aLocalBuildInfofor these functions.) Additionally, the semantics ofwithTestandwithBenchhave changed: they now iterate over all buildable such components, regardless of whether or not they have been enabled; if you only want enabled components, usewithTestLBIandwithBenchLBI.finalizePackageDescriptionis deprecated: its replacementfinalizePDnow takes an extra argumentComponentRequestedSpecwhich specifies what components are to be enabled: use this instead of modifying theComponentin aGenericPackageDescription. (As it’s not possible now,finalizePackageDescriptionwill assume tests/benchmarks are disabled.) If you only need to test if a component is buildable (i.e., it is marked buildable in the Cabal file) use the new functioncomponentBuildable.
- Backwards incompatible change to PackageName(#3896):PackageNameis now opaque; conversion to/fromStringnow works via (old)unPackageNameand (new)mkPackageNamefunctions.
- Backwards incompatible change to ComponentId(#3917):ComponentIdis now opaque; conversion to/fromStringnow works viaunComponentIdandmkComponentIdfunctions.
- Backwards incompatible change to AbiHash(#3921):AbiHashis now opaque; conversion to/fromStringnow works viaunAbiHashandmkAbiHashfunctions.
- Backwards incompatible change to FlagName(#4062):FlagNameis now opaque; conversion to/fromStringnow works viaunFlagNameandmkFlagNamefunctions.
- Backwards incompatible change to Version(#3905): Version is now opaque; conversion to/from[Int]now works viaversionNumbersandmkVersionfunctions.
- Add support for --allow-older(dual to--allow-newer) (#3466)
- Improved an error message for process output decoding errors (#3408).
- getComponentLocalBuildInfo,- withComponentsInBuildOrderand- componentsInBuildOrderare deprecated in favor of a new interface in- Distribution.Types.LocalBuildInfo.
- New autogen-modulesfield. Modules that are built automatically at setup, like Paths_PACKAGENAME or others created with a build-type custom, appear onother-modulesfor the Library, Executable, Test-Suite or Benchmark stanzas or also onexposed-modulesfor libraries but are not really on the package when distributed. This makes commands like sdist fail because the file is not found, so with this new field modules that appear there are treated the same way as Paths_PACKAGENAME was and there is no need to create complex build hooks. Just add the module names onother-modulesandexposed-modulesas always and on the newautogen-modulesbesides. (#3656).
- New ./Setup configureflag--cabal-file, allowing multiple.cabalfiles in a single directory (#3553). Primarily intended for internal use.
- Macros in cabal_macros.hare now ifndef’d, so that they don’t cause an error if the macro is already defined. (#3041)
- ./Setup configurenow accepts a single argument specifying the component to be configured. The semantics of this mode of operation are described in https://github.com/ghc-proposals/ghc-proposals/pull/4
- Internal build-toolsdependencies are now added to PATH upon invocation of GHC, so that they can be conveniently used via-pgmF. (#1541)
- Add support for new caret-style version range operator ^>=(#3705)
- Verbosity -vnow takes an extended format which allows specifying exactly what you want to be logged. The format is[silent|normal|verbose|debug] flags, where flags is a space separated list of flags. At the moment, only the flags +callsite and +callstack are supported; these report the call site/stack of a logging output respectively (these are only supported if Cabal is built with GHC 8.0/7.10.2 or greater, respectively).
- New Distribution.Utils.ShortText.ShortTexttype for representing short text strings compactly (#3898)
- Cabal no longer supports using a version bound to disambiguate between an internal and external package (#4020). This should not affect many people, as this mode of use already did not work with the dependency solver.
- Support for “foreign libraries” (#2540), which are Haskell libraries intended to be used by foreign languages like C. Foreign libraries only work with GHC 7.8 and later.
- Added a technical preview version of integrated doctest support (#4480).
- Added a new scopefield to the executable stanza. Executables withscope: privateget installed into $libexecdir/$libexecsubdir. Additionally $libexecdir now has a subdir structure similar to $lib(sub)dir to allow installing private executables of different packages and package versions alongside one another. Private executables are those that are expected to be run by other programs rather than users. (#3461)
1.24.2.0 Mikhail Glushenkov December 2016
- Fixed a bug in the handling of non-buildable components (#4094).
- Reverted a PVP-noncompliant API change in 1.24.1.0 (#4123).
- Bumped the directory upper bound to < 1.4 (#4158).
1.24.1.0 Ryan Thomas October 2016
- API addition: differenceVersionRanges(#3519).
- Fixed reexported-modules display mangling (#3928).
- Check that the correct cabal-version is specified when the extra-doc-files field is present (#3825).
- Fixed an incorrect invocation of GetShortPathName that was causing build failures on Windows (#3649).
- Linker flags are now set correctly on GHC >= 7.8 (#3443).
1.24.0.0 Ryan Thomas March 2016
- Support GHC 8.
- Deal with extra C sources from preprocessors (#238).
- Include cabal_macros.h when running c2hs (#2600).
- Don’t recompile C sources unless needed (#2601).
- Read builddiroption fromCABAL_BUILDDIRenvironment variable.
- Add --profiling-detail=$levelflag with a default for libraries and executables ofexported-functionsandtoplevel-functionsrespectively (GHC’s-fprof-auto-{exported,top}flags) (#193).
- New custom-setupstanza to specify setup deps. Setup is also built with the cabal_macros.h style macros, for conditional compilation.
- Support Haddock response files (#2746).
- Fixed a bug in the Text instance for Platform (#2862).
- New setup haddockoption:--for-hackage(#2852).
- New --show-detail=direct; like streaming, but allows the test program to detect that is connected to a terminal, and works reliable with a non-threaded runtime (#2911, and serves as a work-around for #2398)
- Library support for multi-instance package DBs (#2948).
- Improved the ./Setup configuresolver (#3082, #3076).
- The --allow-neweroption can be now used with./Setup configure(#3163).
- Added a way to specify extra locations to find OS X frameworks
in (extra-framework-dirs). Can be used both in.cabalfiles and as an argument to./Setup configure(#3158).
- Macros VERSION_$pkgnameandMIN_VERSION_$pkgnameare now also generated for the current package. (#3235).
- Backpack is supported!  Two new fields supported in Cabal
files: signatures and mixins; and a new flag
to setup scripts, --instantiate-with. See https://github.com/ezyang/ghc-proposals/blob/backpack/proposals/0000-backpack.rst for more details.
1.22.8.0 Ryan Thomas March 2016
- Distribution.Simple.Setup: remove job cap. Fixes #3191.
- Check all object file suffixes for recompilation. Fixes #3128.
- Move source files under src/. Fixes #3003.
1.22.7.0 Ryan Thomas January 2016
- Backport #3012 to the 1.22 branch
- Cabal.cabal: change build-type to Simple
- Add foldl’ import
- The Cabal part for fully gcc-like response files
1.22.6.0 Ryan Thomas December 2015
- Relax upper bound to allow upcoming binary-0.8
1.22.5.0 Ryan Thomas November 2015
- Don’t recompile C sources unless needed (#2601). (Luke Iannini)
- Support Haddock response files.
- Add frameworks when linking a dynamic library.
1.22.4.0 Ryan Thomas June 2015
- Add libname install-dirs variable, use it by default. Fixes #2437. (Edward Z. Yang)
- Reduce temporary directory name length, fixes #2502. (Edward Z. Yang)
- Workaround for #2527. (Mikhail Glushenkov)
1.22.3.0 Ryan Thomas April 2015
- Fix for the ghcjs-pkg version number handling (Luite Stegeman)
- filterConfigureFlags: filter more flags (Mikhail Glushenkov)
- Cabal check will fail on -fprof-auto passed as a ghc-option - Fixes #2479 (John Chee)
1.22.2.0 Ryan Thomas March 2015
- Don’t pass --{en,dis}able-profilingto old setup.
- Add -Wall police
- Fix dependencies on old-time
- Fix test interface detailed-0.9 with GHC 7.10
- Fix HPC tests with GHC 7.10
- Make sure to pass the package key to ghc
- Use --package-{name|version}when available for Haddock when available
- Put full package name and version in library names
- Fully specify package key format, so external tools can generate it.
1.22.0.0 Johan Tibell January 2015
- Support GHC 7.10.
- Experimental support for emitting DWARF debug info.
- Preliminary support for relocatable packages.
- Allow cabal to be used inside cabal exec environments.
- hpc: support multiple “ways” (e.g. profiling and vanilla).
- Support GHCJS.
- Improved command line documentation.
- Add -noneconstraint syntax for version ranges (#2093).
- Make the default doc index file path compiler/arch/os-dependent (#2136).
- Warn instead of dying when generating documentation and hscolour isn’t installed (455f51622fa38347db62197a04bb0fa5b928ff17).
- Support the new BinaryLiterals extension (1f25ab3c5eff311ada73c6c987061b80e9bbebd9).
- Warn about ghc-prof-options: -auto-allincabal check(#2162).
- Add preliminary support for multiple instances of the same package version installed side-by-side (#2002).
- New binary build config format - faster build times (#2076).
- Support module thinning and renaming (#2038).
- Add a new license type: UnspecifiedLicense (#2141).
- Remove support for Hugs and nhc98 (#2168).
- Invoke tarwith--formar ustarif possible insdist(#1903).
- Replace --enable-library-coveragewith--enable-coverage, which enables program coverage for all components (#1945).
- Suggest that ExitFailure 9is probably due to memory exhaustion (#1522).
- Drop support for Haddock < 2.0 (#1808, #1718).
- Make cabal test/cabal benchbuild only what’s needed for running tests/benchmarks (#1821).
- Build shared libraries by default when linking executables dynamically.
- Build profiled libraries by default when profiling executables.
1.20.0.4 Ryan Thomas January 2016
- Cabal.cabal: change build-type to Simple.
1.20.0.1 Johan Tibell May 2014
- Fix streaming test output.
1.20.0.0 Johan Tibell April 2014
- Rewrite user guide
- Fix repl Ctrl+C handling
- Add haskell-suite compiler support
- Add HADDOCK_VERSION define
- Allow specifying exact dependency version using hash
- Rename extra-html-files to extra-doc-files
- Add parallel build support for GHC 7.8 and later
- Don’t call ranlib on OS X
- Avoid re-linking executables, test suites, and benchmarks unnecessarily, shortening build times
- Add --allow-newerwhich allows upper version bounds to be ignored
- Add --enable-library-stripping
- Add command for freezing dependencies
- Allow repl to be used outside Cabal packages
- Add --require-sandbox
- Don’t use --strip-unneededon OS X or iOS
- Add new license-files field got additional licenses
- Fix if(solaris) on some Solaris versions
- Don’t use -dylib-install-name on OS X with GHC > 7.8
- Add DragonFly as a known OS
- Improve pretty-printing of Cabal files
- Add test flag --show-details=streamingfor real-time test output
- Add exec command
1.10.2.0 Duncan Coutts June 2011
- Include test suites in cabal sdist
- Fix for conditionals in test suite stanzas in .cabalfiles
- Fix permissions of directories created during install
- Fix for global builds when $HOME env var is not set
1.10.1.0 Duncan Coutts February 2011
- Improved error messages when test suites are not enabled
- Template parameters allowed in test --test-option(s)flag
- Improved documentation of the test feature
- Relaxed QA check on cabal-version when using test-suite sections
- haddockcommand now allows both- --hoogleand- --htmlat the same time
- Find ghc-version-specific instances of the hsc2hs program
- Preserve file executable permissions in sdist tarballs
- Pass gcc location and flags to ./configure scripts
- Get default gcc flags from ghc
1.10.0.0 Duncan Coutts November 2010
- New cabal test feature
- Initial support for UHC
- New default-language and other-languages fields (e.g. Haskell98/2010)
- New default-extensions and other-extensions fields
- Deprecated extensions field (for packages using cabal-version >=1.10)
- Cabal-version field must now only be of the form >= x.y
- Removed deprecated --copy-prefix=feature
- Auto-reconfigure when .cabalfile changes
- Workaround for haddock overwriting .hi and .o files when using TH
- Extra cpp flags used with hsc2hs and c2hs (-D${os}_BUILD_OS etc)
- New cpp define VERSION_ gives string version of dependencies
- User guide source now in markdown format for easier editing
- Improved checks and error messages for C libraries and headers
- Removed BSD4 from the list of suggested licenses
- Updated list of known language extensions
- Fix for include paths to allow C code to import FFI stub.h files
- Fix for intra-package dependencies on OSX
- Stricter checks on various bits of .cabalfile syntax
- Minor fixes for c2hs
1.8.0.6 Duncan Coutts June 2010
- Fix register --global/--user
1.8.0.4 Duncan Coutts March 2010
- Set dylib-install-name for dynalic libs on OSX
- Stricter configure check that compiler supports a package’s extensions
- More configure-time warnings
- Hugs can compile Cabal lib again
- Default datadir now follows prefix on Windows
- Support for finding installed packages for hugs
- Cabal version macros now have proper parenthesis
- Reverted change to filter out deps of non-buildable components
- Fix for registering inplace when using a specific package db
- Fix mismatch between $os and $arch path template variables
- Fix for finding ar.exe on Windows, always pick ghc’s version
- Fix for intra-package dependencies with ghc-6.12
1.8.0.2 Duncan Coutts December 2009
- Support for GHC-6.12
- New unique installed package IDs which use a package hash
- Allow executables to depend on the lib within the same package
- Dependencies for each component apply only to that component (previously applied to all the other components too)
- Added new known license MIT and versioned GPL and LGPL
- More liberal package version range syntax
- Package registration files are now UTF8
- Support for LHC and JHC-0.7.2
- Deprecated RecordPuns extension in favour of NamedFieldPuns
- Deprecated PatternSignatures extension in favor of ScopedTypeVariables
- New VersionRange semantic view as a sequence of intervals
- Improved package quality checks
- Minor simplification in a couple Setup.hshooks
- Beginnings of a unit level testsuite using QuickCheck
- Various bug fixes
- Various internal cleanups
1.6.0.2 Duncan Coutts February 2009
- New configure-time check for C headers and libraries
- Added language extensions present in ghc-6.10
- Added support for NamedFieldPuns extension in ghc-6.8
- Fix in configure step for ghc-6.6 on Windows
- Fix warnings in Path_pkgname.hsmodule on Windows
- Fix for exotic flags in ld-options field
- Fix for using pkg-config in a package with a lib and an executable
- Fix for building haddock docs for exes that use the Paths module
- Fix for installing header files in subdirectories
- Fix for the case of building profiling libs but not ordinary libs
- Fix read-only attribute of installed files on Windows
- Ignore ghc -threaded flag when profiling in ghc-6.8 and older
1.6.0.1 Duncan Coutts October 2008
- Export a compat function to help alex and happy
1.6.0.0 Duncan Coutts October 2008
- Support for ghc-6.10
- Source control repositories can now be specified in .cabalfiles
- Bug report URLs can be now specified in .cabalfiles
- Wildcards now allowed in data-files and extra-source-files fields
- New syntactic sugar for dependencies build-depends: foo ==1.2.*
- New cabal_macros.h provides macros to test versions of dependencies
- Relocatable bindists now possible on unix via env vars
- New exposedfield allows packages to be not exposed by default
- Install dir flags can now use $os and $arch variables
- New --builddirflag allows multiple builds from a single sources dir
- cc-options now only apply to .c files, not for -fvia-C
- cc-options are not longer propagated to dependent packages
- The cpp/cc/ld-options fields no longer use ,as a separator
- hsc2hs is now called using gcc instead of using ghc as gcc
- New api for manipulating sets and graphs of packages
- Internal api improvements and code cleanups
- Minor improvements to the user guide
- Miscellaneous minor bug fixes
1.4.0.2 Duncan Coutts August 2008
- Fix executable stripping default
- Fix striping exes on OSX that export dynamic symbols (like ghc)
- Correct the order of arguments given by --prog-options=
- Fix corner case with overlapping user and global packages
- Fix for modules that use pre-processing and .hs-bootfiles
- Clarify some points in the user guide and readme text
- Fix verbosity flags passed to sub-command like haddock
- Fix sdist --snapshot
- Allow meta-packages that contain no modules or C code
- Make the generated Paths module -Wall clean on Windows
1.4.0.1 Duncan Coutts June 2008
- Fix a bug which caused .to always be in the sources search path
- Haddock-2.2 and later do now support the --hoogleflag
1.4.0.0 Duncan Coutts June 2008
- Rewritten command line handling support
- Command line completion with bash
- Better support for Haddock 2
- Improved support for nhc98
- Removed support for ghc-6.2
- Haddock markup in .lhsfiles now supported
- Default colour scheme for highlighted source code
- Default prefix for --userinstalls is now$HOME/.cabal
- All .cabalfiles are treaded as UTF-8 and must be valid
- Many checks added for common mistakes
- New --package-db=option for specific package databases
- Many internal changes to support cabal-install
- Stricter parsing for version strings, eg dissalows “1.05”
- Improved user guide introduction
- Programatica support removed
- New options --program-prefix/suffixallows eg versioned programs
- Support packages that use .hs-bootfiles
- Fix sdist for Main modules that require preprocessing
- New configure -O flag with optimisation level 0–2
- Provide access to “x-” extension fields through the Cabal api
- Added check for broken installed packages
- Added warning about using inconsistent versions of dependencies
- Strip binary executable files by default with an option to disable
- New options to add site-specific include and library search paths
- Lift the restriction that libraries must have exposed-modules
- Many bugs fixed.
- Many internal structural improvements and code cleanups
1.2.4.0 Duncan Coutts June 2008
- Released with GHC 6.8.3
- Backported several fixes and minor improvements from Cabal-1.4
- Use a default colour scheme for sources with hscolour >=1.9
- Support --hyperlink-sourcefor Haddock >= 2.0
- Fix for running in a non-writable directory
- Add OSX -framework arguments when linking executables
- Updates to the user guide
- Allow build-tools names to include + and _
- Export autoconfUserHooks and simpleUserHooks
- Export ccLdOptionsBuildInfo for Setup.hsscripts
- Export unionBuildInfo and make BuildInfo an instance of Monoid
- Fix to allow the main-ismodule to use a pre-processor
1.2.3.0 Duncan Coutts Nov 2007
- Released with GHC 6.8.2
- Includes full list of GHC language extensions
- Fix infamous dist/conftest.cbug
- Fix configure --interfacedir=
- Find ld.exe on Windows correctly
- Export PreProcessor constructor and mkSimplePreProcessor
- Fix minor bug in unlit code
- Fix some markup in the haddock docs
1.2.2.0 Duncan Coutts Nov 2007
- Released with GHC 6.8.1
- Support haddock-2.0
- Support building DSOs with GHC
- Require reconfiguring if the .cabalfile has changed
- Fix os(windows) configuration test
- Fix building documentation
- Fix building packages on Solaris
- Other minor bug fixes
1.2.1 Duncan Coutts Oct 2007
- To be included in GHC 6.8.1
- New field cpp-optionsused when preprocessing Haskell modules
- Fixes for hsc2hs when using ghc
- C source code gets compiled with -O2 by default
- OS aliases, to allow os(windows) rather than requiring os(mingw32)
- Fix cleaning of stubfiles
- Fix cabal-setup, command line ui that replaces runhaskell Setup.hs
- Build docs even when dependent packages docs are missing
- Allow the --html-dirto be specified at configure time
- Fix building with ghc-6.2
- Other minor bug fixes and build fixes
1.2.0 Duncan Coutts Sept 2007
- To be included in GHC 6.8.x
- New configurations feature
- Can make haddock docs link to highlighted sources (with hscolour)
- New flag to allow linking to haddock docs on the web
- Supports pkg-config
- New field build-toolsfor tool dependencies
- Improved c2hs support
- Preprocessor output no longer clutters source dirs
- Separate includesandinstall-includesfields
- Makefile command to generate makefiles for building libs with GHC
- New --docdirconfigure flag
- Generic --with-prog--prog-argsconfigure flags
- Better default installation paths on Windows
- Install paths can be specified relative to each other
- License files now installed
- Initial support for NHC (incomplete)
- Consistent treatment of verbosity
- Reduced verbosity of configure step by default
- Improved helpfulness of output messages
- Help output now clearer and fits in 80 columns
- New setup register --gen-pkg-configflag for distros
- Major internal refactoring, hooks api has changed
- Dozens of bug fixes
1.1.6.2 Duncan Coutts May 2007
- Released with GHC 6.6.1
- Handle windows text file encoding for .cabalfiles
- Fix compiling a executable for profiling that uses Template Haskell
- Other minor bug fixes and user guide clarifications
1.1.6.1 Duncan Coutts Oct 2006
- fix unlit code
- fix escaping in register.sh
1.1.6 Duncan Coutts Oct 2006
- Released with GHC 6.6
- Added support for hoogle
- Allow profiling and normal builds of libs to be chosen independently
- Default installation directories on Win32 changed
- Register haddock docs with ghc-pkg
- Get haddock to make hyperlinks to dependent package docs
- Added BangPatterns language extension
- Various bug fixes
1.1.4 Duncan Coutts May 2006
- Released with GHC 6.4.2
- Better support for packages that need to install header files
- cabal-setup added, but not installed by default yet
- Implemented setup register --inplace
- Have packages exposed by default with ghc-6.2
- It is no longer necessary to run configurebeforecleanorsdist
- Added support for ghc’s -split-objs
- Initial support for JHC
- Ignore extension fields in .cabalfiles (fields beginning with “x-”)
- Some changes to command hooks API to improve consistency
- Hugs support improvements
- Added GeneralisedNewtypeDeriving language extension
- Added cabal-version field
- Support hidden modules with haddock
- Internal code refactoring
- More bug fixes
1.1.3 Isaac Jones Sept 2005
- WARNING: Interfaces not documented in the user’s guide may change in future releases.
- Move building of GHCi .o libs to the build phase rather than register phase. (from Duncan Coutts)
- Use .tar.gz for source package extension
- Uses GHC instead of cpphs if the latter is not available
- Added experimental “command hooks” which completely override the default behavior of a command.
- Some bugfixes
1.1.1 Isaac Jones July 2005
- WARNING: Interfaces not documented in the user’s guide may change in future releases.
- Handles recursive modules for GHC 6.2 and GHC 6.4.
- Added setup testcommand (Used with UserHook)
- implemented handling of _stub.{c,h,o} files
- Added support for profiling
- Changed install prefix of libraries (pref/pkgname-version to prefix/pkgname-version/compname-version)
- Added pattern guards as a language extension
- Moved some functionality to Language.Haskell.Extension
- Register / unregister .bat files for windows
- Exposed more of the API
- Added support for the hide-all-packages flag in GHC > 6.4
- Several bug fixes
1.0 Isaac Jones March 11 2005
- Released with GHC 6.4, Hugs March 2005, and nhc98 1.18
- Some sanity checking
0.5 Isaac Jones Wed Feb 19 2005
- WARNING: this is a pre-release and the interfaces are still likely to change until we reach a 1.0 release.
- Hooks interfaces changed
- Added preprocessors to user hooks
- No more executable-modules or hidden-modules.  Use
other-modulesinstead.
- Certain fields moved into BuildInfo, much refactoring
- extra-libs->- extra-libraries
- Added --gen-scriptto configure and unconfigure.
- modules-ghc(etc) now- ghc-modules(etc)
- added new fields including synopsis
- Lots of bug fixes
- spaces can sometimes be used instead of commas
- A user manual has appeared (Thanks, ross!)
- for ghc 6.4, configures versioned depends properly
- more features to ./setup haddock
0.4 Isaac Jones Sun Jan 16 2005
- 
Much thanks to all the awesome fptools hackers who have been working hard to build the Haskell Cabal! 
- 
Interface Changes: - 
WARNING: this is a pre-release and the interfaces are still likely to change until we reach a 1.0 release. 
- 
Instead of Package.description, you should name your description files .cabal. In particular, we suggest that you name it .cabal, but this is not enforced (yet). Multiple .cabalfiles in the same directory is an error, at least for now.
- 
./setup install --install-prefixis gone. Use./setup copy--copy-prefixinstead.
- 
The Modulesfield is gone. Usehidden-modules,exposed-modules, andexecutable-modules.
- 
Build-dependsis now a package-only field, and can’t go into executable stanzas. Build-depends is a package-to-package relationship.
- 
Some new fields. Use the Source. 
 
- 
- 
New Features - 
Cabal is now included as a package in the CVS version of fptools. That means it’ll be released as -package Cabalin future versions of the compilers, and if you are a bleeding-edge user, you can grab it from the CVS repository with the compilers.
- 
Hugs compatibility and NHC98 compatibility should both be improved. 
- 
Hooks Interface / Autoconf compatibility: Most of the hooks interface is hidden for now, because it’s not finalized. I have exposed only defaultMainWithHooksanddefaultUserHooks. This allows you to use a ./configure script to preprocessfoo.buildinfo, which gets merged withfoo.cabal. In future releases, we’ll expose UserHooks, but we’re definitely going to change the interface to those. The interface to the two functions I’ve exposed should stay the same, though.
- 
./setup haddock is a baby feature which pre-processes the source code with hscpp and runs haddock on it. This is brand new and hardly tested, so you get to knock it around and see what you think. 
- 
Some commands now actually implement verbosity. 
- 
The preprocessors have been tested a bit more, and seem to work OK. Please give feedback if you use these. 
 
- 
0.3 Isaac Jones Sun Jan 16 2005
- Unstable snapshot release
- From now on, stable releases are even.
0.2 Isaac Jones
- Adds more HUGS support and preprocessor support.
