diff options
author | Edward Z. Yang <ezyang@cs.stanford.edu> | 2014-08-02 13:50:00 +0100 |
---|---|---|
committer | Edward Z. Yang <ezyang@cs.stanford.edu> | 2014-08-05 03:13:40 -0700 |
commit | 207875293fea07aa90efe215369629b657d1875a (patch) | |
tree | 1dbf891a340b07dc2a385225d3b81342fe461ec1 /docs | |
parent | 4accf60184dba550ef0cbdf70fa8e708a4007370 (diff) | |
download | haskell-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.xml | 6 | ||||
-rw-r--r-- | docs/users_guide/packages.xml | 61 |
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> |