033f8da483ce7d05aebbe26e5dc9b656daa7534b
[ghc.git] / docs / users_guide / 8.2.1-notes.rst
1 .. _release-8-2-1:
2
3 Release notes for version 8.2.1
4 ===============================
5
6 The significant changes to the various parts of the compiler are listed
7 in the following sections. There have also been numerous bug fixes and
8 performance improvements over the 8.0 branch.
9
10 Highlights
11 ----------
12
13 The highlights since the 8.0 branch are:
14
15 - TODO FIXME
16 - SCC annotations can now be used for declarations.
17
18 Full details
19 ------------
20
21 Language
22 ~~~~~~~~
23
24 -  TODO FIXME.
25
26 - Pattern synonym signatures can now be applied to multiple patterns, just like
27   value-level binding signatures. See :ref:`patsyn-typing` for details.
28
29 Compiler
30 ~~~~~~~~
31
32 -  TODO FIXME.
33
34 - Old profiling flags ``-auto-all``, ``-auto``, and ``-caf-all`` are deprecated
35   and their usage provokes a compile-time warning.
36
37 - Support for adding cost centres to declarations is added. The same `SCC`
38   syntax can be used, in addition to a new form for specifying the cost centre
39   name. See :ref:`scc-pragma` for examples.
40
41 - It is now possible to explicitly pick a strategy to use when deriving a
42   class instance using the :ghc-flag:`-XDerivingStrategies` language extension
43   (see :ref:`deriving-strategies`).
44
45 GHCi
46 ~~~~
47
48 -  TODO FIXME.
49
50 - Added :ghc-flag:`-flocal-ghci-history` which uses current directory for `.ghci-history`.
51
52 Template Haskell
53 ~~~~~~~~~~~~~~~~
54
55 -  TODO FIXME.
56
57 -  Reifying types that contain unboxed tuples now works correctly. (Previously,
58    Template Haskell reified unboxed tuples as boxed tuples with twice their
59    appropriate arity.)
60
61 -  Splicing singleton unboxed tuple types (e.g., ``(# Int #)``) now works
62    correctly. Previously, Template Haskell would implicitly remove the
63    parentheses when splicing, which would turn ``(# Int #)`` into ``Int``.
64
65 Runtime system
66 ~~~~~~~~~~~~~~
67
68 -  TODO FIXME.
69
70 - The :ref:`heap profiler <prof-heap>` can now emit heap census data to the GHC
71   event log, allowing heap profiles to be correlated with other tracing events
72   (see :ghc-ticket:`11094`).
73
74 - Added processor group support for Windows. This allows the runtime to allocate
75   threads to all cores in systems which have multiple processor groups.
76   (e.g. > 64 cores, see :ghc-ticket:`11054`)
77
78 Build system
79 ~~~~~~~~~~~~
80
81 -  TODO FIXME.
82
83 Package system
84 ~~~~~~~~~~~~~~
85
86 -  TODO FIXME.
87
88 hsc2hs
89 ~~~~~~
90
91 -  TODO FIXME.
92
93 Libraries
94 ---------
95
96 array
97 ~~~~~
98
99 -  Version number XXXXX (was 0.5.0.0)
100
101
102 .. _lib-base:
103
104 base
105 ~~~~
106
107 See ``changelog.md`` in the ``base`` package for full release notes.
108
109 -  Version number 4.10.0.0 (was 4.9.0.0)
110
111 - ``Data.Either`` now provides ``fromLeft`` and ``fromRight``
112
113 - ``Data.Type.Coercion`` now provides ``gcoerceWith``, which is analogous to
114   ``gcastWith`` from ``Data.Type.Equality``.
115
116 - The ``Read1`` and ``Read2`` classes in ``Data.Functor.Classes`` have new
117   methods, ``liftReadList(2)`` and ``liftReadListPrec(2)``, that are defined in
118   terms of ``ReadPrec`` instead of ``ReadS``. This matches the interface
119   provided in GHC's version of the ``Read`` class, and allows users to write
120   more efficient ``Read1`` and ``Read2`` instances.
121
122 binary
123 ~~~~~~
124
125 -  Version number XXXXX (was 0.7.1.0)
126
127 bytestring
128 ~~~~~~~~~~
129
130 -  Version number XXXXX (was 0.10.4.0)
131
132 Cabal
133 ~~~~~
134
135 -  Version number XXXXX (was 1.18.1.3)
136
137 containers
138 ~~~~~~~~~~
139
140 -  Version number XXXXX (was 0.5.4.0)
141
142 deepseq
143 ~~~~~~~
144
145 -  Version number XXXXX (was 1.3.0.2)
146
147 directory
148 ~~~~~~~~~
149
150 -  Version number XXXXX (was 1.2.0.2)
151
152 filepath
153 ~~~~~~~~
154
155 -  Version number XXXXX (was 1.3.0.2)
156
157 ghc
158 ~~~
159
160 -  
161 ghc-boot
162 ~~~~~~~~
163
164 -  This is an internal package. Use with caution.
165
166 -  TODO FIXME.
167
168 ghc-prim
169 ~~~~~~~~
170
171 -  Version number XXXXX (was 0.3.1.0)
172
173 -  Added new ``isByteArrayPinned#`` and ``isMutableByteArrayPinned#`` operation.
174
175 -  New function ``noinline`` in ``GHC.Magic`` lets you mark that a function
176    should not be inlined.  It is optimized away after the simplifier runs.
177
178 haskell98
179 ~~~~~~~~~
180
181 -  Version number XXXXX (was 2.0.0.3)
182
183 haskell2010
184 ~~~~~~~~~~~
185
186 -  Version number XXXXX (was 1.1.1.1)
187
188 hoopl
189 ~~~~~
190
191 -  Version number XXXXX (was 3.10.0.0)
192
193 hpc
194 ~~~
195
196 -  Version number XXXXX (was 0.6.0.1)
197
198 integer-gmp
199 ~~~~~~~~~~~
200
201 -  Version number XXXXX (was 0.5.1.0)
202
203 old-locale
204 ~~~~~~~~~~
205
206 -  Version number XXXXX (was 1.0.0.6)
207
208 old-time
209 ~~~~~~~~
210
211 -  Version number XXXXX (was 1.1.0.2)
212
213 process
214 ~~~~~~~
215
216 -  Version number XXXXX (was 1.2.0.0)
217
218 template-haskell
219 ~~~~~~~~~~~~~~~~
220
221 -  Version number XXXXX (was 2.9.0.0)
222
223 -  Added support for unboxed sums :ghc-ticket:`12478`.
224
225 -  Added support for visible type applications :ghc-ticket:`12530`.
226
227 time
228 ~~~~
229
230 -  Version number XXXXX (was 1.4.1)
231
232 unix
233 ~~~~
234
235 -  Version number XXXXX (was 2.7.0.0)
236
237 Win32
238 ~~~~~
239
240 -  Version number XXXXX (was 2.3.0.1)
241
242 Known bugs
243 ----------
244
245 -  TODO FIXME