Merge pull request #10525 from 9999years/field-stanza-names
[cabal.git] / release-notes / Cabal-3.8.0.20220526.md
blob42e58aec85fcaf8c2341220900d82197a9843f8d
1 Cabal 3.8.0.20220526 Changelog
2 ---
4 ### Significant changes
6 - Cabal init rewrite [#1074](https://github.com/haskell/cabal/issues/1074) [#6758](https://github.com/haskell/cabal/issues/6758) [#6864](https://github.com/haskell/cabal/issues/6864) [#7251](https://github.com/haskell/cabal/issues/7251) [#7255](https://github.com/haskell/cabal/issues/7255) [#7256](https://github.com/haskell/cabal/issues/7256) [#7273](https://github.com/haskell/cabal/issues/7273)
8   - Restructures the `cabal init` command to fix historical
9     issues. All flags are preserved.
10     - Codebases for interactive and non-interactive flags
11       are disentangled.
12     - Data structures now exploit relevant stanza structure
13       and formatters only care about stanza data
14     - Heuristics and prompts have a pure and impure implementation.
16   - Sets default behavior to be `--interactive` as opposed to
17     `--non-interactive`.
19   - Rewrites tests to achieve 98% coverage
20     - Golden files now test every stanza individually
21     - Every flag is covered by a unit test
22     - Interactive, simple, and non-interactive workflows are
23       covered.
25 - Make Paths_ modules work with non-standard preludes again [#7494](https://github.com/haskell/cabal/issues/7494) [#7649](https://github.com/haskell/cabal/issues/7649)
27   - Reverts #7510 that failed on Windows when used with pre-generated scripts included in packages such as network, time, process.
28   - Adds a subtler fix/workaround for the deficiencies of new autoconf versions on Windows.
30 - Windows: rewrite paths to configure [#7494](https://github.com/haskell/cabal/issues/7494) [#7649](https://github.com/haskell/cabal/issues/7649)
32 - Expose `cabal-install` as library [#1597](https://github.com/haskell/cabal/issues/1597) [#3781](https://github.com/haskell/cabal/issues/3781) [#4798](https://github.com/haskell/cabal/issues/4798) [#6090](https://github.com/haskell/cabal/issues/6090) [#7224](https://github.com/haskell/cabal/issues/7224) [#7358](https://github.com/haskell/cabal/pull/7358)
33 - Allow preprocessors to register a reordering [#55](https://github.com/haskell/cabal/issues/55) [#1906](https://github.com/haskell/cabal/issues/1906)
35   - Changes the PreProcessor type to include a field ppOrdering so that modules are presented to the preprocessor in the right order (w.r.t. dependencies)
37 - Use ghc -flink-rts option when available [#7763](https://github.com/haskell/cabal/issues/7763) [#7764](https://github.com/haskell/cabal/pull/7764) [#8111](https://github.com/haskell/cabal/pull/8111)
39   Previously Cabal did quite some headstands to link against libHSrts.
40   Note only this is complex but it couples very tightly to GHC's implementation.
41   Thankfully, as of GHC 9.0 GHC provides a -flink-rts flag for precisely this purpose.
42   Use it when available.
44   It fixed a bug which make Cabal unusable to build foreign libraries for windows and ghc 9.0 or 9.2.
45   See <https://gitlab.haskell.org/ghc/ghc/-/issues/20520>
47 - Remove the Generic instance of LicenseId [#8074](https://github.com/haskell/cabal/issues/8074) [#8117](https://github.com/haskell/cabal/pull/8117)
49   - The `Generic` instance of LicenseId is removed, due to the extraordinary amount of memory required to compile
50     the Generic instances of large sum types in GHC.
52 ### Other changes
54 - Handle option argument parse errors without 'error' [#7573](https://github.com/haskell/cabal/issues/7573) [#7579](https://github.com/haskell/cabal/pull/7579)
56   - Errors parsing arguments such as `-v=3` no longer result in
57     stack traces.
58   - `Distribution.ReadE.readEOrFail` was removed.
60 - Fix bugs in filename validation [#7426](https://github.com/haskell/cabal/issues/7426) [#7429](https://github.com/haskell/cabal/pull/7429) [#7479](https://github.com/haskell/cabal/pull/7479)
62   - Relative paths starting with single-character directories are now properly allowed
63   - `cabal check` rejects paths which are invalid on Windows or in tarballs
65 - Fix test --enable-coverage for multi-package projects [#5213](https://github.com/haskell/cabal/issues/5213) [#5433](https://github.com/haskell/cabal/issues/5433) [#7200](https://github.com/haskell/cabal/issues/7200) [#7250](https://github.com/haskell/cabal/pull/7250) [#7467](https://github.com/haskell/cabal/pull/7467)
67   - Fix `cabal test --enable-coverage` for multi-package projects by invoking `hpc markup --include=` and listing only modules of libraries of the single tested package.
69 - Make cabal respect setgid permission bit when creating directories [#7560](https://github.com/haskell/cabal/issues/7560) [#7572](https://github.com/haskell/cabal/pull/7572)
71   - Previously cabal would override an admin's choice to use setgid on the
72     .cabal directory by using hardcoded file and directory modes upon
73     creation. Instead we now take what the system decides and only add to
74     that set of permissions.
76 - Handle conditionals in duplicate module checks [#4629](https://github.com/haskell/cabal/issues/4629) [#7525](https://github.com/haskell/cabal/issues/7525) [#7616](https://github.com/haskell/cabal/pull/7616)
78   Improves `cabal check` logic for duplicate modules to take into account conditional branches. If a module appears on both sides of an `if/else` clause in a cabal file, it is now correctly not reported as a duplicate.
80 - Backtrack when no pkg-config is present [#7448](https://github.com/haskell/cabal/issues/7448) [#7621](https://github.com/haskell/cabal/pull/7621)
82   When solving for pkgconfig-depends, when pkg-config is not present, the cabal solver will now backtrack and try a different automatic flag and dependency configuration, just as it does if pkg-config is present, but does not contain the specified package.
84 - Add code-generators field to test-suite stanza [#4500](https://github.com/haskell/cabal/issues/4500) [#7688](https://github.com/haskell/cabal/pull/7688)
86   Test-suite stanzas now may contain a `code-generators:` field that can be used to run executables as preprocessors which take existing locations of library code and cabal-generated ghc build flags, and output new modules for use in the test stanza. This can be used to automatically generate drivers for "discover" style tests, including doctests.
88 - Terminate subprocesses when killed [#7914](https://github.com/haskell/cabal/issues/7914) [#7921](https://github.com/haskell/cabal/pull/7921)
90   - cabal (and 'cabal run' in particular) no longer leaves children running
91     when it is killed (unix)
93 - Cleanup subprocess helpers, remove obsolete functions [#7995](https://github.com/haskell/cabal/pull/7995)
95   - Distribution.Compat.Process: Remove createProcess, runInteractiveProcess
96     and rawSystem.
97   - Distribution.Simple.Utils: Remove printRawCommandAndArgs,
98     printRawCommandAndArgsAndEnv and createProcessWithEnv.
100 - Allow glob-star matches with literal filenames (no extensions) [#5883](https://github.com/haskell/cabal/issues/5883) [#8005](https://github.com/haskell/cabal/pull/8005)
102   - Cabal file glob syntax extended to allow matches of the form dir/**/FileNoExtension
104 - Flatten duplicate warnings about experimental features [#8023](https://github.com/haskell/cabal/pull/8023)
106   - Make builds that use experimental Cabal language features less noisy. At -v1
107     (normal) we show just first instance of use of experimental cabal language
108   features, along with count of further occurrences in the same file.
110 - Fix Cabal not finding public sublibraries of installed packages [#7270](https://github.com/haskell/cabal/issues/7270) [#8089](https://github.com/haskell/cabal/pull/8089)
112   Fix bug in lookup of installed sublibraries with nonexact dependencies (ie. when
113   not using --exact-configuration). That is the mode of operation of distribution
114   packages, so this should allow distros to package Cabal packages with multiple
115   libraries.
117 - Make type field optional for tests and benchmarks [#7459](https://github.com/haskell/cabal/issues/7459) [#8115](https://github.com/haskell/cabal/pull/8115)
119   Allow the omission of the `type` field in `test-suite` and `benchmark` stanzas
120   when the type can be inferred by the presence of `main-is` or `test-module`.
122 - Improve error message for empty --allow-newer=  [#7740](https://github.com/haskell/cabal/issues/7740) [#8140](https://github.com/haskell/cabal/pull/8140)
124   Instead of internal error, the message now explains that empty argument for
126   argument) means.
128 - Create Cabal-syntax for .cabal files [#7559](https://github.com/haskell/cabal/issues/7559) [#7620](https://github.com/haskell/cabal/pull/7620)
129 - Fix haddock command via Setup.hs for internal libraries [#1919](https://github.com/haskell/cabal/issues/1919) [#7827](https://github.com/haskell/cabal/pull/7827)
130 - `ghc-options` and `--with-gcc` are now passed to GHC when compiling C and C++ sources [#4439](https://github.com/haskell/cabal/issues/4439) [#5440](https://github.com/haskell/cabal/pull/5440) [#7874](https://github.com/haskell/cabal/pull/7874)
131 - 'cabal check' to fail when no upper bounds for base or Cabal are present in setup dependencies [#4683](https://github.com/haskell/cabal/issues/4683) [#5370](https://github.com/haskell/cabal/pull/5370) [#7409](https://github.com/haskell/cabal/pull/7409)
132 - --repl-options doesn’t split on whitespace [#6190](https://github.com/haskell/cabal/issues/6190) [#7799](https://github.com/haskell/cabal/pull/7799)
133 - '--repl-no-load' option skips startup modules load in REPL [#7541](https://github.com/haskell/cabal/issues/7541) [#7578](https://github.com/haskell/cabal/pull/7578)
134 - Add -c alias for --constraint command line flag [#7765](https://github.com/haskell/cabal/issues/7765) [#7766](https://github.com/haskell/cabal/pull/7766)
135 - Add "prompt" strategy when symlinking binaries. [#5672](https://github.com/haskell/cabal/pull/5672)
136 - Add fields extra-libraries-static and extra-lib-dirs-static [#6688](https://github.com/haskell/cabal/issues/6688) [#7399](https://github.com/haskell/cabal/issues/7399) [#7536](https://github.com/haskell/cabal/pull/7536)
137 - Paths passed to GHC are now relative to the current working directory
138 - Automatically pipe auth from repo uris into curl transport. [#4743](https://github.com/haskell/cabal/issues/4743) [#7630](https://github.com/haskell/cabal/pull/7630)
139 - raise lower bound of process and remove compatibility shims [#7922](https://github.com/haskell/cabal/pull/7922)
140 - changes the cabal check warning about long synopsis, so it warns only synopsis bigger than the set size [#7932](https://github.com/haskell/cabal/issues/7932) [#7933](https://github.com/haskell/cabal/pull/7933)
141 - Remove bootstrapping plan files from version control, and simplify bootstrap update Makefile targets. [#7949](https://github.com/haskell/cabal/pull/7949)
142 - Remove deprecated file finding functions [#7955](https://github.com/haskell/cabal/pull/7955)
143 - Support GHC 9.4's `clang`-based Windows toolchain [#8062](https://github.com/haskell/cabal/pull/8062)
144 - Add support for the 64-bit S390X architecture [#8065](https://github.com/haskell/cabal/pull/8065)
145 - Add wasm32-wasi to recognized arch/os [#8096](https://github.com/haskell/cabal/pull/8096)
146 - Unmarked "visibility: public" and "build-depends: pkg:lib" syntaxes as experimental, allowing Hackage upload of packages exposing or using multiple public libraries [#6801](https://github.com/haskell/cabal/issues/6801) [#7286](https://github.com/haskell/cabal/issues/7286) [#8089](https://github.com/haskell/cabal/pull/8089)
147 - Sync repo darcs [#7137](https://github.com/haskell/cabal/pull/7137)
149 - *Cabal-syntax* Derive Eq for DependencyMap [#7849](https://github.com/haskell/cabal/issues/7849) [#8061](https://github.com/haskell/cabal/pull/8061)
150 - *Cabal-syntax* Allow trailing whitespace after flags in cabal.project [#7279](https://github.com/haskell/cabal/issues/7279) [#8006](https://github.com/haskell/cabal/pull/8006)
151 - *Cabal-syntax* Update the SPDX License List to version 3.16 [#8126](https://github.com/haskell/cabal/issues/8126) [#8127](https://github.com/haskell/cabal/pull/8127)
153   The LicenseId and LicenseExceptionId types are updated to reflect the SPDX License List version 3.16 (2022-02-06).
155 - Added fields :pkg-field:`extra-libraries-static` and
156   :pkg-field:`extra-lib-dirs-static` to allow Haskell libraries to remember
157   linker flags needed for fully static linking of system libraries into executables. [#7536](https://github.com/haskell/cabal/pull/7536)
159 - The existing field :pkg-field:`pkgconfig-depends` can used to append the relevant
160   output of ``pkg-config --libs --static`` to these new fields automatically.
161   When :pkg-field:`extra-libraries-static` is not given, it defaults to
162   :pkg-field:`extra-libraries`. When :pkg-field:`extra-lib-dirs-static` is not
163   given, it defaults to :pkg-field:`extra-lib-dirs`. [#7536](https://github.com/haskell/cabal/pull/7536)