Revert zipWith strictification (re #9949)
[ghc.git] / libraries / base / changelog.md
1 # Changelog for [`base` package](http://hackage.haskell.org/package/base)
2
3 ## 4.8.0.0  *TBA*
4
5   * Bundled with GHC 7.10.1
6
7   * Make `Applicative` a superclass of `Monad`
8
9   * Add reverse application operator `Data.Function.(&)`
10
11   * Add `Data.List.sortOn` sorting function
12
13   * Add `System.Exit.die`
14
15   * Deprecate `versionTags` field of `Data.Version.Version`.
16     Add `makeVersion :: [Int] -> Version` constructor function to aid
17     migration to a future `versionTags`-less `Version`.
18
19   * Add `IsList Version` instance
20
21   * Weaken RealFloat constraints on some `Data.Complex` functions
22
23   * Add `Control.Monad.(<$!>)` as a strict version of `(<$>)`
24
25   * The `Data.Monoid` module now has the `PolyKinds` extension
26     enabled, so that the `Monoid` instance for `Proxy` are polykinded
27     like `Proxy` itself is.
28
29   * Make `abs` and `signum` handle (-0.0) correctly per IEEE-754.
30
31   * Re-export `Data.Word.Word` from `Prelude`
32
33   * Add `countLeadingZeros` and `countTrailingZeros` methods to
34     `Data.Bits.FiniteBits` class
35
36   * Add `Data.List.uncons` list destructor (#9550)
37
38   * Export `Monoid(..)` from `Prelude`
39
40   * Export `Foldable(..)` from `Prelude`
41     (hiding `fold`, `foldl'`, `foldr'`, and `toList`)
42
43   * Export `Traversable(..)` from `Prelude`
44
45   * Set fixity for `Data.Foldable.{elem,notElem}` to match the
46     conventional one set for `Data.List.{elem,notElem}` (#9610)
47
48   * Turn `toList`, `elem`, `sum`, `product`, `maximum`, and `minimum`
49     into `Foldable` methods (#9621)
50
51   * Replace the `Data.List`-exported functions
52
53     ```
54     all, and, any, concat, concatMap, elem, find, product, sum,
55     mapAccumL, mapAccumR
56     ```
57
58     by re-exports of their generalised `Data.Foldable`/`Data.Traversable`
59     counterparts.  In other words, unqualified imports of `Data.List`
60     and `Data.Foldable`/`Data.Traversable` no longer lead to conflicting
61     definitions. (#9586)
62
63   * Replace the `Control.Monad`-exported functions
64
65     ```
66     sequence_, msum, mapM_, forM_,
67     forM, mapM, sequence
68     ```
69
70     by re-exports of their generalised `Data.Foldable`/`Data.Traversable`
71     counterparts.  In other words, unqualified imports of `Control.Monad`
72     and `Data.Foldable`/`Data.Traversable` no longer lead to conflicting
73     definitions. (#9586)
74
75   * Generalise `Control.Monad.{when,unless,guard}` from `Monad` to
76     `Applicative` and from `MonadPlus` to `Alternative` respectively.
77
78   * Generalise `Control.Monad.{foldM,foldM_}` to `Foldable`
79
80   * `scanr`, `mapAccumL` and `filterM` now take part in list fusion (#9355,
81     #9502, #9546)
82
83   * Remove deprecated `Data.OldTypeable` (#9639)
84
85   * New module `Data.Bifunctor` providing the `Bifunctor(bimap,first,second)`
86     class (previously defined in `bifunctors` package) (#9682)
87
88   * New module `Data.Void` providing the canonical uninhabited type `Void`
89     (previously defined in `void` package) (#9814)
90
91   * Update Unicode class definitions to Unicode version 7.0
92
93   * Add `Alt`, an `Alternative` wrapper, to `Data.Monoid`. (#9759)
94
95   * Add `isSubsequenceOf` to `Data.List` (#9767)
96
97   * The arguments to `==` and `eq` in `Data.List.nub` and `Data.List.nubBy`
98     are swapped, such that `Data.List.nubBy (<) [1,2]` now returns `[1]`
99     instead of `[1,2]` (#2528, #3280, #7913)
100
101   * New module `Data.Functor.Identity` (previously provided by `transformers`
102     package). (#9664)
103
104   * Add `scanl'`, a strictly accumulating version of `scanl`, to `Data.List`
105     and `Data.OldList`. (#9368)
106
107   * Add `fillBytes` to `Foreign.Marshal.Utils`.
108
109   * Add new `displayException` method to `Exception` typeclass. (#9822)
110
111   * Add `Data.Bits.toIntegralSized`, a size-checked version of
112     `fromIntegral`. (#9816)
113
114   * New module `Numeric.Natural` providing new `Natural` type
115     representing non-negative arbitrary-precision integers.  The `GHC.Natural`
116     module exposes additional GHC-specific primitives. (#9818)
117
118   * Add `(Storable a, Integeral a) => Storable (Ratio a)` instance (#9826)
119
120   * Add `Storable a => Storable (Complex a)` instance (#9826)
121
122   * New module `GHC.RTS.Flags` that provides accessors to runtime flags.
123
124   * Expose functions for per-thread allocation counters and limits in `GHC.Conc`
125
126         disableAllocationLimit :: IO ()
127         enableAllocationLimit :: IO ()
128         getAllocationCounter :: IO Int64
129         setAllocationCounter :: Int64 -> IO ()
130
131     together with a new exception `AllocationLimitExceeded`.
132
133   * Make `read . show = id` for `Data.Fixed` (#9240)
134
135   * Add `calloc` and `callocBytes` to `Foreign.Marshal.Alloc`. (#9859)
136
137   * Add `callocArray` and `callocArray0` to `Foreign.Marshal.Array`. (#9859)
138
139   * Restore invariant in `Data (Ratio a)` instance (#10011)
140
141 ## 4.7.0.2  *Dec 2014*
142
143   * Bundled with GHC 7.8.4
144
145   * Fix performance bug in `Data.List.inits` (#9345)
146
147   * Fix handling of null bytes in `Debug.Trace.trace` (#9395)
148
149 ## 4.7.0.1  *Jul 2014*
150
151   * Bundled with GHC 7.8.3
152
153   * Unhide `Foreign.ForeignPtr` in Haddock (#8475)
154
155   * Fix recomputation of `TypeRep` in `Typeable` type-application instance
156     (#9203)
157
158   * Fix regression in Data.Fixed Read instance (#9231)
159
160   * Fix `fdReady` to honor `FD_SETSIZE` (#9168)
161
162 ## 4.7.0.0  *Apr 2014*
163
164   * Bundled with GHC 7.8.1
165
166   * Add `/Since: 4.[4567].0.0/` Haddock annotations to entities
167     denoting the package version, when the given entity was introduced
168     (or its type signature changed in a non-compatible way)
169
170   * The `Control.Category` module now has the `PolyKinds` extension
171     enabled, meaning that instances of `Category` no longer need be of
172     kind `* -> * -> *`.
173
174   * There are now `Foldable` and `Traversable` instances for `Either a`,
175    `Const r`, and `(,) a`.
176
177   * There are now `Show`, `Read`, `Eq`, `Ord`, `Monoid`, `Generic`, and
178     `Generic1` instances for `Const`.
179
180   * There is now a `Data` instance for `Data.Version`.
181
182   * A new `Data.Bits.FiniteBits` class has been added to represent
183     types with fixed bit-count. The existing `Bits` class is extended
184     with a `bitSizeMaybe` method to replace the now obsolete
185     `bitsize` method.
186
187   * `Data.Bits.Bits` gained a new `zeroBits` method which completes the
188     `Bits` API with a direct way to introduce a value with all bits cleared.
189
190   * There are now `Bits` and `FiniteBits` instances for `Bool`.
191
192   * There are now `Eq`, `Ord`, `Show`, `Read`, `Generic`. and `Generic1`
193     instances for `ZipList`.
194
195   * There are now `Eq`, `Ord`, `Show` and `Read` instances for `Down`.
196
197   * There are now `Eq`, `Ord`, `Show`, `Read` and `Generic` instances
198     for types in GHC.Generics (`U1`, `Par1`, `Rec1`, `K1`, `M1`,
199     `(:+:)`, `(:*:)`, `(:.:)`).
200
201   * `Data.Monoid`: There are now `Generic` instances for `Dual`, `Endo`,
202     `All`, `Any`, `Sum`, `Product`, `First`, and `Last`; as well as
203     `Generic1` instances for `Dual`, `Sum`, `Product`, `First`, and `Last`.
204
205   * The `Data.Monoid.{Product,Sum}` newtype wrappers now have `Num` instances.
206
207   * There are now `Functor` instances for `System.Console.GetOpt`'s
208     `ArgOrder`, `OptDescr`, and `ArgDescr`.
209
210   * A zero-width unboxed poly-kinded `Proxy#` was added to
211     `GHC.Prim`. It can be used to make it so that there is no the
212     operational overhead for passing around proxy arguments to model
213     type application.
214
215   * New `Data.Proxy` module providing a concrete, poly-kinded proxy type.
216
217   * New `Data.Coerce` module which exports the new `Coercible` class
218     together with the `coerce` primitive which provide safe coercion
219     (wrt role checking) between types with same representation.
220
221   * `Control.Concurrent.MVar` has a new implementation of `readMVar`,
222     which fixes a long-standing bug where `readMVar` is only atomic if
223     there are no other threads running `putMVar`.  `readMVar` now is
224     atomic, and is guaranteed to return the value from the first
225     `putMVar`.  There is also a new `tryReadMVar` which is a
226     non-blocking version.
227
228   * New `Control.Concurrent.MVar.withMVarMasked` which executes
229     `IO` action with asynchronous exceptions masked in the same style
230     as the existing `modifyMVarMasked` and `modifyMVarMasked_`.
231
232   * New `threadWait{Read,Write}STM :: Fd -> IO (STM (), IO ())`
233     functions added to `Control.Concurrent` for waiting on FD
234     readiness with STM actions.
235
236   * Expose `Data.Fixed.Fixed`'s constructor.
237
238   * There are now byte endian-swapping primitives
239     `byteSwap{16,32,64}` available in `Data.Word`, which use
240     optimized machine instructions when available.
241
242   * `Data.Bool` now exports `bool :: a -> a -> Bool -> a`, analogously
243     to `maybe` and `either` in their respective modules.
244
245   * `Data.Either` now exports `isLeft, isRight :: Either a b -> Bool`.
246
247   * `Debug.Trace` now exports `traceId`, `traceShowId`, `traceM`,
248     and `traceShowM`.
249
250   * `Data.Functor` now exports `($>)` and `void`.
251
252   * Rewrote portions of `Text.Printf`, and made changes to `Numeric`
253     (added `Numeric.showFFloatAlt` and `Numeric.showGFloatAlt`) and
254     `GHC.Float` (added `formatRealFloatAlt`) to support it.  The
255     rewritten version is extensible to user types, adds a "generic"
256     format specifier "`%v`", extends the `printf` spec to support much
257     of C's `printf(3)` functionality, and fixes the spurious warnings
258     about using `Text.Printf.printf` at `(IO a)` while ignoring the
259     return value.  These changes were contributed by Bart Massey.
260
261   * The minimal complete definitions for all type-classes with cyclic
262     default implementations have been explicitly annotated with the
263     new `{-# MINIMAL #-}` pragma.
264
265   * `Control.Applicative.WrappedMonad`, which can be used to convert a
266     `Monad` to an `Applicative`, has now a
267     `Monad m => Monad (WrappedMonad m)` instance.
268
269   * There is now a `Generic` and a `Generic1` instance for `WrappedMonad`
270     and `WrappedArrow`.
271
272   * Handle `ExitFailure (-sig)` on Unix by killing process with signal `sig`.
273
274   * New module `Data.Type.Bool` providing operations on type-level booleans.
275
276   * Expose `System.Mem.performMinorGC` for triggering minor GCs.
277
278   * New `System.Environment.{set,unset}Env` for manipulating
279     environment variables.
280
281   * Add `Typeable` instance for `(->)` and `RealWorld`.
282
283   * Declare CPP header `<Typeable.h>` officially obsolete as GHC 7.8+
284     does not support hand-written `Typeable` instances anymore.
285
286   * Remove (unmaintained) Hugs98 and NHC98 specific code.
287
288   * Optimize `System.Timeout.timeout` for the threaded RTS.
289
290   * Remove deprecated functions `unsafeInterleaveST`, `unsafeIOToST`,
291     and `unsafeSTToIO` from `Control.Monad.ST`.
292
293   * Add a new superclass `SomeAsyncException` for all asynchronous exceptions
294     and makes the existing `AsyncException` and `Timeout` exception children
295     of `SomeAsyncException` in the hierarchy.
296
297   * Remove deprecated functions `blocked`, `unblock`, and `block` from
298     `Control.Exception`.
299
300   * Remove deprecated function `forkIOUnmasked` from `Control.Concurrent`.
301
302   * Remove deprecated function `unsafePerformIO` export from `Foreign`
303     (still available via `System.IO.Unsafe.unsafePerformIO`).
304
305   * Various fixes and other improvements (see Git history for full details).