summaryrefslogtreecommitdiff
path: root/docs/users_guide
diff options
context:
space:
mode:
Diffstat (limited to 'docs/users_guide')
-rw-r--r--docs/users_guide/8.10.1-notes.rst388
-rw-r--r--docs/users_guide/8.8.1-notes.rst273
-rw-r--r--docs/users_guide/release-notes.rst2
3 files changed, 0 insertions, 663 deletions
diff --git a/docs/users_guide/8.10.1-notes.rst b/docs/users_guide/8.10.1-notes.rst
deleted file mode 100644
index a1bf31519b..0000000000
--- a/docs/users_guide/8.10.1-notes.rst
+++ /dev/null
@@ -1,388 +0,0 @@
-.. _release-8-10-1:
-
-Version 8.10.1
-==============
-
-The significant changes to the various parts of the compiler are listed in the
-following sections.
-
-
-Highlights
-----------
-
-- The :extension:`UnliftedNewtypes` extension.
-
-Full details
-------------
-
-Language
-~~~~~~~~
-
-- Kind variables are no longer implicitly quantified when an explicit ``forall`` is used, see
- `GHC proposal #24
- <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0024-no-kind-vars.rst>`__.
- :ghc-flag:`-Wimplicit-kind-vars` is now obsolete.
-
-- Kind variables are no longer implicitly quantified in constructor declarations: ::
-
- data T a = T1 (S (a :: k)) | forall (b::k). T2 (S b) -- no longer accepted
- data T (a :: k) = T1 (S (a :: k)) | forall (b::k). T2 (S b) -- still accepted
-
-- Implicitly quantified kind variables are no longer put in front of other variables: ::
-
- f :: Proxy (a :: k) -> Proxy (b :: j)
-
- ghci> :t +v f -- old order:
- f :: forall k j (a :: k) (b :: j). Proxy a -> Proxy b
-
- ghci> :t +v f -- new order:
- f :: forall k (a :: k) j (b :: j). Proxy a -> Proxy b
-
- This is a breaking change for users of :extension:`TypeApplications`.
-
-- In type synonyms and type family equations, free variables on the RHS are no longer
- implicitly quantified unless used in an outermost kind annotation: ::
-
- type T = Just (Nothing :: Maybe a) -- no longer accepted
- type T = Just Nothing :: Maybe (Maybe a) -- still accepted
-
-- A new extension :extension:`StandaloneKindSignatures` allows one to explicitly
- specify the kind of a type constructor, as proposed in `GHC proposal #54
- <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0054-kind-signatures.rst>`__: ::
-
- type TypeRep :: forall k. k -> Type
- data TypeRep a where
- TyInt :: TypeRep Int
- TyMaybe :: TypeRep Maybe
- TyApp :: TypeRep a -> TypeRep b -> TypeRep (a b)
-
- Analogous to function type signatures, a :ref:`standalone kind signature
- <standalone-kind-signatures>` enables polymorphic recursion. This feature is
- a replacement for :extension:`CUSKs`.
-
-- GHC now parses visible, dependent quantifiers (as proposed in
- `GHC proposal 35
- <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0035-forall-arrow.rst>`__),
- such as the following: ::
-
- data Proxy :: forall k -> k -> Type
-
- See the :ref:`section on explicit kind quantification
- <explicit-kind-quantification>` for more details.
-
-- Type variables in associated type family default declarations can now be
- explicitly bound with a ``forall`` when :extension:`ExplicitForAll` is
- enabled, as in the following example: ::
-
- class C a where
- type T a b
- type forall a b. T a b = Either a b
-
- This has a couple of knock-on consequences:
-
- - Wildcard patterns are now permitted on the left-hand sides of default
- declarations, whereas they were rejected by previous versions of GHC.
-
- - It used to be the case that default declarations supported occurrences of
- left-hand side arguments with higher-rank kinds, such as in the following
- example: ::
-
- class C a where
- type T a (f :: forall k. k -> Type)
- type T a (f :: forall k. k -> Type) = f Int
-
- This will no longer work unless ``f`` is explicitly quantified with a
- ``forall``, like so: ::
-
- class C a where
- type T a (f :: forall k. k -> Type)
- type forall a (f :: forall k. k -> Type).
- T a f = f Int
-
-- A new extension :extension:`UnliftedNewtypes` that relaxes restrictions
- around what kinds of types can appear inside of the data constructor
- for a ``newtype``. This was proposed in
- `GHC proposal #13 <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0013-unlifted-newtypes.rst>`__.
-
-- A new extension :extension:`ImportQualifiedPost` allows the syntax
- ``import M qualified``, that is, to annotate a module as qualified by
- writing ``qualified`` after the module name.
- This was proposed in `GHC proposal #49 <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0049-module-qualified-syntax.rst>`__.
-
-- New flag :ghc-flag:`-Wderiving-defaults` that controls a warning
- message when both :extension:`DeriveAnyClass` and
- :extension:`GeneralizedNewtypeDeriving` are enabled and no explicit
- deriving strategy is in use. The warning is enabled by default and
- has been present in earlier GHC versions but without the option of
- disabling it. For example, this code would trigger the warning: ::
-
- class C a
- newtype T a = MkT a deriving C
-
-- GHC now performs more validity checks on inferred type signatures. One
- consequence of this change is that some programs that used to be accepted
- will no longer compile without enabling the required language extensions.
- For example, in these two modules: ::
-
- {-# LANGUAGE RankNTypes #-}
- module A where
-
- foo :: (forall a. a -> a) -> b -> b
- foo f x = f x
-
- module B where
-
- import A
-
- bar = foo
-
- Notice that ``A`` enables :ghc-flag:`-XRankNTypes`, but ``B`` does not.
- Previous versions of GHC would allow ``bar`` to typecheck, even though its
- inferred type is higher-rank. GHC 8.10 will now reject this, as one must now
- enable :ghc-flag:`-XRankNTypes` in ``B`` to accept the inferred type signature.
-
-- Type family dependencies (also known as injective type families)
- sometimes now need ``-XUndecidableInstances`` in order to be
- accepted. Here is an example::
-
- type family F1 a = r | r -> a
- type family F2 a = r | r -> a
- type instance F2 [a] = Maybe (F1 a)
-
- Because GHC needs to look under a type family to see that ``a`` is determined
- by the right-hand side of ``F2``\'s equation, this now needs ``-XUndecidableInstances``.
- The problem is very much akin to its need to detect some functional dependencies.
-
-- The pattern-match coverage checker received a number of improvements wrt.
- correctness and performance.
-
- Checking against user-defined COMPLETE pragmas
- "just works" now, so that we could move away from the
- `complicated procedure for disambiguation <https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/glasgow_exts.html#disambiguating-between-multiple-complete-pragmas>`__
- we had in place before.
-
- Previously, the checker performed really badly on some inputs and had no
- good story for graceful degradation in these situations. These situations
- should occur much less frequently now and degradation happens much more
- smoothly, while still producing useful, sound results (see
- :ghc-flag:`-fmax-pmcheck-models=⟨n⟩`).
-
-Compiler
-~~~~~~~~
-
-- Add new flags :ghc-flag:`-Wunused-record-wildcards` and
- :ghc-flag:`-Wredundant-record-wildcards` which warn users when they have
- redundant or unused uses of a record wildcard match.
-
-- Calls to ``memset`` and ``memcpy`` are now unrolled more aggressively
- and the produced code is more efficient on `x86_64` with added
- support for 64-bit ``MOV``\s. In particular, ``setByteArray#`` and
- ``copyByteArray#`` calls that were not optimized before, now will
- be. See :ghc-ticket:`16052`.
-- GHC's runtime linker no longer uses global state. This allows programs
- that use the GHC API to safely use multiple GHC sessions in a single
- process, as long as there are no native dependencies that rely on
- global state.
-
-- When loading modules that use :extension:`UnboxedTuples` or
- :extension:`UnboxedSums` into GHCi, it will now automatically enable
- :ghc-flag:`-fobject-code` for these modules and all modules they depend on.
- Before this change, attempting to load these modules into the interpreter
- would just fail, and the only convenient workaround was to enable
- :ghc-flag:`-fobject-code` for all modules. See the
- :ref:`GHCi FAQ <ghci-faq>` for further details.
-
-- The eventlog now contains events for biographical and retainer profiling.
- The biographical profiling events all appear at the end of the eventlog but
- the sample start event contains a timestamp of when the census occurred.
- The retainer profiling events are emitted using the standard events.
-
-- The eventlog now logs the cost centre stack on each sample. This enables
- the ``.prof`` file to be partially reconstructed from the eventlog.
-
-- Add new flag :ghc-flag:`-fkeep-going` which makes the compiler
- continue as far as it can despite errors.
-
-- Deprecated flag ``-fwarn-hi-shadowing`` because it was not
- implemented correctly, and appears to be largely unused. This flag
- will be removed in a later version of GHC.
-
-- Windows bindist has been updated to GCC 9.2 and binutils 2.32. These binaries have
- been patched to no longer have have the MAX_PATH limit. Windows users should no longer
- have any issues with long path names.
-
-- Introduce ``DynFlags`` plugins, that allow users to modidy the ``DynFlags``
- that GHC is going to use when processing a set of files, from plugins.
- They can be used for applying tiny configuration changes, registering hooks
- and much more. See the :ref:`user guide <dynflags_plugins>` for
- more details as well as an example.
-
-- Deprecated flag ``-fmax-pmcheck-iterations`` in favor of
- :ghc-flag:`-fmax-pmcheck-models=⟨n⟩`, which uses a completely different mechanism.
-
-- GHC now writes ``.o`` files atomically, resulting in reduced chances
- of truncated files when a build is cancelled or the computer crashes.
-
- This fixes numerous bug reports in Stack and Cabal where GHC was not
- able to recover from such situations by itself and users reported having
- to clean the build directory.
-
- Other file types are not yet written atomically.
- Users that observe related problems should report them on
- `GHC issue #14533 <https://gitlab.haskell.org/ghc/ghc/issues/14533>`__.
- This fix is part of the
- `Stack initiative to get rid of persistent build errors due to non-atomic
- file writes across the Haskell tooling ecosystem
- <https://github.com/commercialhaskell/stack/issues/4559>`__.
-
-
-GHCi
-~~~~
-
-- Added a command :ghci-cmd:`:instances` to show the class instances available for a type.
-
-- Added new debugger commands :ghci-cmd:`:disable` and :ghci-cmd:`:enable` to
- disable and re-enable breakpoints.
-
-- Improved command name resolution with option ``!``. For example, ``:k!``
- resolves to ``:kind!``.
-
-Runtime system
-~~~~~~~~~~~~~~
-
-- The runtime system linker now marks loaded code as non-writable (see
- :ghc-ticket:`14069`) on all tier-1 platforms. This is necesaary for
- out-of-the-box compatibility with OpenBSD and macOS Catalina (see
- :ghc-ticket:`17353`)
-
-- The RTS API now exposes :ref:`an interface <event_log_output_api>` to
- configure ``EventLogWriters``, allowing eventlog data to fed to sinks other
- than ``.eventlog`` files.
-
-- A new ``+RTS`` flag ``--disable-delayed-os-memory-return`` was added to make
- for accurate resident memory usage of the program as shown in memory
- usage reporting tools (e.g. the ``RSS`` column in ``top`` and ``htop``).
-
- This makes it easier to check the real memory usage of Haskell programs.
-
- Using this new flag is expected to make the program slightly slower.
-
- Without this flag, the (Linux) RTS returns unused memory "lazily" to the OS.
- This has making the memory available to other processes while also allowing
- the RTS to re-use the memory very efficiently (without zeroing pages) in case
- it needs it again, but common tools will incorrectly show such memory as
- occupied by the RTS (because they do not process the ``LazyFree`` field in
- ``/proc/PID/smaps``).
-
-Template Haskell
-~~~~~~~~~~~~~~~~
-
-- The ``Lift`` typeclass is now levity-polymorphic and has a ``liftTyped``
- method. Previously disallowed instances for unboxed tuples, unboxed sums, an
- primitive unboxed types have also been added. Finally, the code generated by
- :extension:`DeriveLift` has been simplified to take advantage of expression
- quotations.
-
-- Using ``TupleT 1``, ``TupE [exp]``, or ``TupP [pat]`` will now produce unary
- tuples (i.e., involving the ``Unit`` type from ``GHC.Tuple``) instead of
- silently dropping the parentheses. This brings Template Haskell's treatment
- of boxed tuples in line with that of unboxed tuples, as ``UnboxedTupleT`,
- ``UnboxedTupE``, and ``UnboxedTupP`` also produce unary unboxed tuples
- (i.e., ``Unit#``) when applied to only one argument.
-
-- GHC's constraint solver now solves constraints in each top-level group
- sooner. This has practical consequences for Template Haskell, as TH splices
- necessarily separate top-level groups. For example, the following program
- would compile in previous versions of GHC, but not in GHC 8.10: ::
-
- data T = MkT
-
- tStr :: String
- tStr = show MkT
-
- $(return [])
-
- instance Show T where
- show MkT = "MkT"
-
- This is because each top-level group's constraints are solved before moving
- on to the next, and since the top-level group for ``tStr`` appears before the
- top-level group that defines a ``Show T`` instance, GHC 8.10 will throw an
- error about a missing ``Show T`` instance in the expression ``show MkT``. The
- issue can be fixed by rearranging the order of declarations. For instance,
- the following will compile: ::
-
- data T = MkT
-
- instance Show T where
- show MkT = "MkT"
-
- $(return [])
-
- tStr :: String
- tStr = show MkT
-
-- TH splices by default don't generate warnings anymore. For example,
- ``$([d| f :: Int -> void; f x = case x of {} |])`` used to generate a
- pattern-match exhaustivity warning, which now it doesn't. The user can
- activate warnings for TH splices with :ghc-flag:`-fenable-th-splice-warnings`.
- The reason for opt-in is that the offending code might not have been generated
- by code the user has control over, for example the ``singletons`` or ``lens``
- library.
-
-``ghc-prim`` library
-~~~~~~~~~~~~~~~~~~~~
-
-- Add new ``bitReverse#`` primops that, for a ``Word`` of 8, 16, 32 or 64 bits,
- reverse the order of its bits e.g. ``0b110001`` becomes ``0b100011``.
- These primitives use optimized machine instructions when available.
-
-``ghc`` library
-~~~~~~~~~~~~~~~
-
-``base`` library
-~~~~~~~~~~~~~~~~
-
-Included libraries
-------------------
-
-The package database provided with this distribution also contains a number of
-packages other than GHC itself. See the changelogs provided with these packages
-for further change information.
-
-.. ghc-package-list::
-
- libraries/array/array.cabal: Dependency of ``ghc`` library
- libraries/base/base.cabal: Core library
- libraries/binary/binary.cabal: Dependency of ``ghc`` library
- libraries/bytestring/bytestring.cabal: Dependency of ``ghc`` library
- libraries/Cabal/Cabal/Cabal.cabal: Dependency of ``ghc-pkg`` utility
- libraries/containers/containers/containers.cabal: Dependency of ``ghc`` library
- libraries/deepseq/deepseq.cabal: Dependency of ``ghc`` library
- libraries/directory/directory.cabal: Dependency of ``ghc`` library
- libraries/exceptions/exceptions.cabal: Dependency of ``haskeline`` library
- libraries/filepath/filepath.cabal: Dependency of ``ghc`` library
- compiler/ghc.cabal: The compiler itself
- libraries/ghci/ghci.cabal: The REPL interface
- libraries/ghc-boot/ghc-boot.cabal: Internal compiler library
- libraries/ghc-boot-th/ghc-boot-th.cabal: Internal compiler library
- libraries/ghc-compact/ghc-compact.cabal: Core library
- libraries/ghc-heap/ghc-heap.cabal: GHC heap-walking library
- libraries/ghc-prim/ghc-prim.cabal: Core library
- libraries/haskeline/haskeline.cabal: Dependency of ``ghci`` executable
- libraries/hpc/hpc.cabal: Dependency of ``hpc`` executable
- libraries/integer-gmp/integer-gmp.cabal: Core library
- libraries/libiserv/libiserv.cabal: Internal compiler library
- libraries/mtl/mtl.cabal: Dependency of ``Cabal`` library
- libraries/parsec/parsec.cabal: Dependency of ``Cabal`` library
- libraries/pretty/pretty.cabal: Dependency of ``ghc`` library
- libraries/process/process.cabal: Dependency of ``ghc`` library
- libraries/stm/stm.cabal: Dependency of ``haskeline`` library
- libraries/template-haskell/template-haskell.cabal: Core library
- libraries/terminfo/terminfo.cabal: Dependency of ``haskeline`` library
- libraries/text/text.cabal: Dependency of ``Cabal`` library
- libraries/time/time.cabal: Dependency of ``ghc`` library
- libraries/transformers/transformers.cabal: Dependency of ``ghc`` library
- libraries/unix/unix.cabal: Dependency of ``ghc`` library
- libraries/Win32/Win32.cabal: Dependency of ``ghc`` library
- libraries/xhtml/xhtml.cabal: Dependency of ``haddock`` executable
diff --git a/docs/users_guide/8.8.1-notes.rst b/docs/users_guide/8.8.1-notes.rst
deleted file mode 100644
index 4dd7ff1b0f..0000000000
--- a/docs/users_guide/8.8.1-notes.rst
+++ /dev/null
@@ -1,273 +0,0 @@
-.. _release-8-8-1:
-
-Version 8.8.1
-=============
-
-The significant changes to the various parts of the compiler are listed in the
-following sections. There have also been numerous bug fixes and performance
-improvements over the 8.6.1 release.
-
-
-Highlights
-----------
-
-The highlights, since the 8.6.1 release, are:
-
-- Many, many bug fixes.
-- A new code layout algorithm for x86.
-
-
-Full details
-------------
-
-Language
-~~~~~~~~
-
-- GHC now supports visible kind applications, as described in
- `GHC proposal #15 <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0015-type-level-type-applications.rst>`__. This extends the existing
- :ref:`visible type applications <visible-type-application>` feature to permit
- type applications at the type level (e.g., ``f :: Proxy ('Just @Bool 'True)``) in
- addition to the term level (e.g., ``g = Just @Bool True``).
-
-- GHC now allows explicitly binding type variables in type family instances and
- rewrite rules, as described in
- `GHC proposal #7 <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0007-instance-foralls.rst>`__. For instance: ::
-
- type family G a b where
- forall x y. G [x] (Proxy y) = Double
- forall z. G z z = Bool
- {-# RULES "example" forall a. forall (x :: a). id x = x #-}
-
-- :extension:`ScopedTypeVariables`: The type variable that a type signature on
- a pattern can bring into scope can now stand for arbitrary types. Previously,
- they could only stand in for other type variables, but this restriction was deemed
- unnecessary in `GHC proposal #29 <https://github.com/ghc-proposals/ghc-proposals/blob/master/proposals/0029-scoped-type-variables-types.rst>`__. Also see :ghc-ticket:`15050`.
-
-- The pattern-match coverage checker now checks for cases that are unreachable
- due to constructors have strict argument types. For instance, in the
- following example: ::
-
- data K = K1 | K2 !Void
-
- f :: K -> ()
- f K1 = ()
-
- ``K2`` cannot be matched on in ``f``, since it is impossible to construct a
- terminating value of type ``Void``. Accordingly, GHC will not warn about
- ``K2`` (whereas previous versions of GHC would).
-
-- ``(!)`` and ``(.)`` are now valid type operators: ::
-
- type family a ! b
- type family a . b
-
-- ``forall`` is now always a keyword in types to provide more helpful
- error messages when ``-XExplicitForall`` is off.
-
-- An existential context no longer requires parenthesization: ::
-
- class a + b
- data D1 = forall a b. (a + b) => D1 a b
- data D2 = forall a b. a + b => D2 a b -- now allowed
-
-- ``{-# UNPACK #-}`` annotation no longer requires parenthesization: ::
-
- data T = MkT1 { a :: {-# UNPACK #-} (Maybe Int && Bool) }
- | MkT2 { a :: {-# UNPACK #-} Maybe Int && Bool } -- now allowed
-
- data G where
- MkG1 :: {-# UNPACK #-} (Maybe Int && Bool) -> G
- MkG2 :: {-# UNPACK #-} Maybe Int && Bool -> G -- now allowed
-
-- The requirement that kind signatures always be parenthesized has been relaxed.
- For instance, it is now permissible to write ``Proxy '(a :: A, b :: B)``
- (previous GHC versions required extra parens: ``Proxy '((a :: A), (b :: B))``).
-
-- :ghc-flag:`-Woverflowed-literals` checks all literals. Previously, it would
- only inspect boxed expression literals.
-
-- :ghc-flag:`-Wempty-enumerations` now also works for ``Numeric.Natural``.
-
-Compiler
-~~~~~~~~
-
-- The final phase of the ``MonadFail`` proposal has been implemented.
- Accordingly, the ``MonadFailDesugaring`` language extension is now
- deprecated, as its effects are always enabled. Similarly, the
- ``-Wnoncanonical-monadfail-instances`` flag is also deprecated, as there is
- no longer any way to define a "non-canonical" ``Monad`` or ``MonadFail``
- instance.
-
-- New :ghc-flag:`-keep-hscpp-files` to keep the output of the CPP pre-processor.
-
-- The :ghc-flag:`-Wcompat` warning group now includes :ghc-flag:`-Wstar-is-type`.
-
-- New :ghc-flag:`-Wunused-packages` warning reports unused packages.
-
-- The :ghc-flag:`-fllvm-pass-vectors-in-regs` flag is now deprecated as vector
- arguments are now passed in registers by default.
-
-- The :ghc-flag:`-fblock-layout-cfg` flag enables a new code layout algorithm on x86.
- This is enabled by default at :ghc-flag:`-O` and :ghc-flag:`-O2`.
-
-- The deprecated ghc-flag ``-Wamp`` has been removed.
-
-- Add new :ghc-flag:`-Wmissing-deriving-strategies` flag that warns users when they are not
- taking advantage of :extension:`DerivingStrategies`. The warning is supplied at each
- ``deriving`` site.
-
-- Support for object splitting with the flag ``-split-objs`` is removed. Using
- this flag now results in a warning and does nothing. Use
- :ghc-flag:`-split-sections` instead.
-
-
-Runtime system
-~~~~~~~~~~~~~~
-
-- Add and document new FFI functions ``hs_lock_stable_ptr_table``
- and ``hs_unlock_stable_ptr_table``. These replace the undocumented
- functions ``hs_lock_stable_tables`` and ``hs_unlock_stable_tables``,
- respectively. The latter should now be considered deprecated.
-
-- Document the heretofore undocumented FFI function
- ``hs_free_stable_ptr_unsafe``, used in conjunction with manual
- locking and unlocking.
-
-- The runtime linker on Windows has been overhauled to properly handle section
- alignment, lower the amount of wasted memory and lower the amount of in use memory.
- See :ghc-ticket:`13617`. Note that committed memory may be slightly higher.
-
-- The output filename used for :ref:`eventlog output <rts-eventlog>` can now be
- specified with the :rts-flag:`-ol ⟨filename⟩` flag.
-
-- Add support for generating a new type of output: extended interfaces files.
- Generation of these files, which sport a ``.hie`` suffix, is enabled via the
- ``-fwrite-ide-info`` flag. See :ref:`hie-options` for more information.
-
-- A new flag ``-xp`` is added on x86_64. When it is passed, the runtime linker
- can load object files compiled with ``-fPIC -fexternal-dynamic-refs``
- anywhere in the address space. This used to be restricted to the low 2Gb.
-
-Template Haskell
-~~~~~~~~~~~~~~~~
-
-- Reifying type classes no longer shows redundant class type variables and
- contexts in the type signature of each class method. For instance,
- reifying the following class: ::
-
- class C a where
- method :: a
-
- Used to produce the following: ::
-
- class C a where
- method :: forall a. C a => a
-
- Where the ``forall a. C a =>`` part is entirely redundant. This part is no
- longer included when reifying ``C``. It's possible that this may break some
- code which assumes the existence of ``forall a. C a =>``.
-
-- Template Haskell has been updated to support visible kind applications and
- explicit ``foralls`` in type family instances and ``RULES``. These required
- a couple of backwards-incompatible changes to the ``template-haskell`` API.
- Please refer to the
- `GHC 8.8 Migration Guide <https://gitlab.haskell.org/ghc/ghc/wikis/migration/8.8#template-haskell-21500>`__
- for more details.
-
-- Template Haskell now supports implicit parameters and recursive do.
-
-- Template Haskell splices can now embed assembler source (:ghc-ticket:`16180`)
-
-``ghc-prim`` library
-~~~~~~~~~~~~~~~~~~~~
-
-- GHC now exposes a new primop, ``traceBinaryEvent#``. This primop writes
- eventlog events similar to ``traceEvent#`` but allows the user to pass
- the event payload as a binary blob instead of a zero-terminated
- ``ByteString``.
-
-- The ``StableName#`` type parameter now has a phantom role instead of
- a representational one. There is really no reason to care about the
- type of the underlying object.
-
-``ghc`` library
-~~~~~~~~~~~~~~~
-
-
-``base`` library
-~~~~~~~~~~~~~~~~
-
-- The final phase of the ``MonadFail`` proposal has been implemented. As a
- result of this change:
-
- - The ``fail`` method of ``Monad`` has been removed in favor of the method of
- the same name in the ``MonadFail`` class.
-
- - ``MonadFail(fail)`` is now re-exported from the ``Prelude`` and
- ``Control.Monad`` modules.
-
- These are breaking changes that may require you to update your code. Please
- refer to the
- `GHC 8.8 Migration Guide <https://gitlab.haskell.org/ghc/ghc/wikis/migration/8.8#base-41300>`__
- for more details.
-
-- Support the characters from recent versions of Unicode (up to v. 12) in literals
- (see :ghc-ticket:`5518`).
-
-- The ``StableName`` type parameter now has a phantom role instead of
- a representational one. There is really no reason to care about the
- type of the underlying object.
-
-- The functions ``zipWith3`` and ``zip3`` in ``Prelude`` can now fuse,
- together with ``zipWith4`` to ``zipWith7`` as well as their
- tuple counterparts in ``Data.List``.
-
-Build system
-~~~~~~~~~~~~
-
-- Configure: Add ALEX and HAPPY variables to explicitly set the alex and happy
- programs to use.
-- Configure: Deprecate --with-ghc=ARG in favour of the GHC variable.
-
-Included libraries
-------------------
-
-The package database provided with this distribution also contains a number of
-packages other than GHC itself. See the changelogs provided with these packages
-for further change information.
-
-.. ghc-package-list::
-
- libraries/array/array.cabal: Dependency of ``ghc`` library
- libraries/base/base.cabal: Core library
- libraries/binary/binary.cabal: Dependency of ``ghc`` library
- libraries/bytestring/bytestring.cabal: Dependency of ``ghc`` library
- libraries/Cabal/Cabal/Cabal.cabal: Dependency of ``ghc-pkg`` utility
- libraries/containers/containers/containers.cabal: Dependency of ``ghc`` library
- libraries/deepseq/deepseq.cabal: Dependency of ``ghc`` library
- libraries/directory/directory.cabal: Dependency of ``ghc`` library
- libraries/filepath/filepath.cabal: Dependency of ``ghc`` library
- compiler/ghc.cabal: The compiler itself
- libraries/ghci/ghci.cabal: The REPL interface
- libraries/ghc-boot/ghc-boot.cabal: Internal compiler library
- libraries/ghc-boot-th/ghc-boot-th.cabal: Internal compiler library
- libraries/ghc-compact/ghc-compact.cabal: Core library
- libraries/ghc-heap/ghc-heap.cabal: GHC heap-walking library
- libraries/ghc-prim/ghc-prim.cabal: Core library
- libraries/haskeline/haskeline.cabal: Dependency of ``ghci`` executable
- libraries/hpc/hpc.cabal: Dependency of ``hpc`` executable
- libraries/integer-gmp/integer-gmp.cabal: Core library
- libraries/libiserv/libiserv.cabal: Internal compiler library
- libraries/mtl/mtl.cabal: Dependency of ``Cabal`` library
- libraries/parsec/parsec.cabal: Dependency of ``Cabal`` library
- libraries/pretty/pretty.cabal: Dependency of ``ghc`` library
- libraries/process/process.cabal: Dependency of ``ghc`` library
- libraries/stm/stm.cabal: Dependency of ``haskeline`` library
- libraries/template-haskell/template-haskell.cabal: Core library
- libraries/terminfo/terminfo.cabal: Dependency of ``haskeline`` library
- libraries/text/text.cabal: Dependency of ``Cabal`` library
- libraries/time/time.cabal: Dependency of ``ghc`` library
- libraries/transformers/transformers.cabal: Dependency of ``ghc`` library
- libraries/unix/unix.cabal: Dependency of ``ghc`` library
- libraries/Win32/Win32.cabal: Dependency of ``ghc`` library
- libraries/xhtml/xhtml.cabal: Dependency of ``haddock`` executable
diff --git a/docs/users_guide/release-notes.rst b/docs/users_guide/release-notes.rst
index 179402e238..3fce057729 100644
--- a/docs/users_guide/release-notes.rst
+++ b/docs/users_guide/release-notes.rst
@@ -5,5 +5,3 @@ Release notes
:maxdepth: 1
8.12.1-notes
- 8.10.1-notes
- 8.8.1-notes