summaryrefslogtreecommitdiff
path: root/docs
diff options
context:
space:
mode:
authorEdward Z. Yang <ezyang@cs.stanford.edu>2014-08-02 13:50:00 +0100
committerEdward Z. Yang <ezyang@cs.stanford.edu>2014-08-05 03:13:40 -0700
commit207875293fea07aa90efe215369629b657d1875a (patch)
tree1dbf891a340b07dc2a385225d3b81342fe461ec1 /docs
parent4accf60184dba550ef0cbdf70fa8e708a4007370 (diff)
downloadhaskell-207875293fea07aa90efe215369629b657d1875a.tar.gz
Thinning and renaming modules from packages on the command line.
Summary: This patch set adds support for extra syntax on -package and related arguments which allow you to thin and rename modules from a package. For example, this argument: -package "base (Data.Bool as Bam, Data.List)" adds two more modules into scope, Bam and Data.List, without adding any of base's other modules to scope. These flags are additive: so, for example, saying: -hide-all-packages -package base -package "base (Data.Bool as Bam)" will provide both the normal bindings for modules in base, as well as the module Bam. There is also a new debug flag -ddump-mod-map which prints the state of the module mapping database. H = hidden, E = exposed (so for example EH says the module in question is exported, but in a hidden package.) Module suggestions have been minorly overhauled to work better with reexports: if you have -package "base (Data.Bool as Bam)" and mispell Bam, GHC will suggest "Did you mean Bam (defined via package flags to be base:Data.Bool)"; and generally you will get more accurate information. Also, fix a bug where we suggest the -package flag when we really need the -package-key flag. NB: The renaming afforded here does *not* affect what wired in symbols GHC generates. (But it does affect implicit prelude!) ToDo: add 'hiding' functionality, to make it easier to support the alternative prelude use-case. ToDo: Cabal support Signed-off-by: Edward Z. Yang <ezyang@cs.stanford.edu> Test Plan: new tests and validate Reviewers: simonpj, simonmar, hvr, austin Subscribers: simonmar, relrod, ezyang, carter Differential Revision: https://phabricator.haskell.org/D113 GHC Trac Issues: #9375
Diffstat (limited to 'docs')
-rw-r--r--docs/users_guide/glasgow_exts.xml6
-rw-r--r--docs/users_guide/packages.xml61
2 files changed, 62 insertions, 5 deletions
diff --git a/docs/users_guide/glasgow_exts.xml b/docs/users_guide/glasgow_exts.xml
index 3d2e634c51..00f43153eb 100644
--- a/docs/users_guide/glasgow_exts.xml
+++ b/docs/users_guide/glasgow_exts.xml
@@ -2461,7 +2461,7 @@ warns if you hide something that the imported module does not export.
</sect3>
<sect3>
- <title>Package-qualified imports</title>
+ <title id="package-qualified-imports">Package-qualified imports</title>
<para>With the <option>-XPackageImports</option> flag, GHC allows
import declarations to be qualified by the package name that the
@@ -2484,7 +2484,9 @@ import "network" Network.Socket
added mainly so that we can build backwards-compatible versions of
packages when APIs change. It can lead to fragile dependencies in
the common case: modules occasionally move from one package to
- another, rendering any package-qualified imports broken.</para>
+ another, rendering any package-qualified imports broken.
+ See also <xref linkend="package-thinning-and-renaming" /> for
+ an alternative way of disambiguating between module names.</para>
</sect3>
<sect3 id="safe-imports-ext">
diff --git a/docs/users_guide/packages.xml b/docs/users_guide/packages.xml
index 50549b409c..ee29cb1c2f 100644
--- a/docs/users_guide/packages.xml
+++ b/docs/users_guide/packages.xml
@@ -88,7 +88,11 @@ $ ghc-pkg list
to expose a hidden package or hide an exposed one. Only modules
from exposed packages may be imported by your Haskell code; if
you try to import a module from a hidden package, GHC will emit
- an error message.
+ an error message. If there are a multiple exposed versions of a package,
+ GHC will prefer the latest one. Additionally, some packages may be
+ broken: that is, they are missing from the package database, or one of
+ their dependencies are broken; in this case; these packages are excluded
+ from the default set of packages.
</para>
<para>
@@ -137,8 +141,11 @@ exposed-modules: Network.BSD,
(e.g. <literal>network-1.0</literal>) or the version
number can be omitted if there is only one version of the
package installed. If there are multiple versions
- of <replaceable>P</replaceable> installed, then all other
- versions will become hidden.</para>
+ of <replaceable>P</replaceable> installed and
+ <option>-hide-all-packages</option> was not specified, then all
+ other versions will become hidden. <option>-package</option>
+ supports thinning and renaming described in <xref
+ linkend="package-thinning-and-renaming" />.</para>
<para>The <option>-package <replaceable>P</replaceable></option>
option also causes package <replaceable>P</replaceable> to
@@ -187,6 +194,8 @@ exposed-modules: Network.BSD,
more robust way to name packages, and can be used to
select packages that would otherwise be shadowed. Cabal
passes <option>-package-id</option> flags to GHC.
+ <option>-package-id</option> supports thinning and renaming
+ described in <xref linkend="package-thinning-and-renaming" />.
</para>
</listitem>
</varlistentry>
@@ -363,6 +372,52 @@ _ZCMain_main_closure
name.</para>
</sect2>
+ <sect2 id="package-thinning-and-renaming">
+ <title>Thinning and renaming modules</title>
+
+ <para>When incorporating packages from multiple sources, you may end up
+ in a situation where multiple packages publish modules with the same name.
+ Previously, the only way to distinguish between these modules was to
+ use <xref linkend="package-qualified-imports" />. However, since GHC 7.10,
+ the <option>-package</option> flags (and their variants) have been extended
+ to allow a user to explicitly control what modules a package brings into
+ scope, by analogy to the import lists that users can attach to module imports.
+ </para>
+
+ <para>
+ The basic syntax is that instead of specifying a package name P to the package
+ flag <literal>-package</literal>, instead we specify both a package name and a
+ parenthesized, comma-separated list of module names to import. For example,
+ <literal>-package "base (Data.List, Data.Bool)"</literal> makes only
+ <literal>Data.List</literal> and <literal>Data.Bool</literal> visible from
+ package <literal>base</literal>.
+ We also support renaming of modules, in case you need to refer to both modules
+ simultaneously; this is supporting by writing <literal>OldModName as
+ NewModName</literal>, e.g. <literal>-package "base (Data.Bool as
+ Bool)</literal>. It's important to specify quotes
+ so that your shell passes the package name and thinning/renaming list as a
+ single argument to GHC.</para>
+
+ <para>Package imports with thinning/renaming do not hide other versions of the
+ package: e.g. if containers-0.9 is already exposed, <literal>-package
+ "containers-0.8 (Data.List as ListV8)"</literal> will only add an additional
+ binding to the environment. Similarly, <literal>-package "base (Data.Bool as
+ Bool)" -package "base (Data.List as List)"</literal> is equivalent to
+ <literal>-package "base (Data.Bool as Bool, Data.List as List)"</literal>.
+ Literal names must refer to modules defined by the original package, so for
+ example <literal>-package "base (Data.Bool as Bool, Bool as Baz)"</literal> is
+ invalid unless there was a <literal>Bool</literal> module defined in the
+ original package. Hiding a package also clears all of its renamings. </para>
+
+ <para>
+ You can use renaming to provide an alternate prelude, e.g.
+ <literal>-hide-all-packages -package "basic-prelude (BasicPrelude as
+ Prelude)"</literal>, in lieu of the <xref
+ linkend="rebindable-syntax">NoImplicitPrelude</xref> extension.
+ </para>
+
+ </sect2>
+
<sect2 id="package-databases">
<title>Package Databases</title>