1. 30 Oct, 2015 3 commits
    • Simon Peyton Jones's avatar
      Fix unused-import stuff in a better way · 9376249b
      Simon Peyton Jones authored
      The fix for Trac #10890 in commit 1818b48e, namely
         Fix incorrect import warnings when methods with identical names are imported
      was wrong, as demonstrated by the new test T10890_2.  It suppressed
      far too many warnings!
      This patch fixes the original problem in a different way, by making
      RdrName.greUsedRdrName a bit cleverer.
      But this too is not really the Right Thing.  I think the Right Thing is
      to store the /GRE/ in the tcg_used_rdrnames, not the /RdrName/.  That
      would be a lot simpler and more direct.
      But one step at a time.
    • Simon Peyton Jones's avatar
      Swap prov/req in variable naming in Parser.y · 9b3a0588
      Simon Peyton Jones authored
      This is a follow on to the patch for Trac #10928.
      It's a local renaming of variables only; no change in behaviour.
    • Erik de Castro Lopo's avatar
      Linker: Fix type in m32_free_internal · 8ddf4174
      Erik de Castro Lopo authored
      The code:
          uint64_t c = __sync_sub_and_fetch((uint64_t*)addr, 1);
      was causing GCC to emit atomic instructions for 64 bit values which
      are not available on PowerPC. However, since PowerPC only has a 32
      bit address space, use of a 64 bit value is superflous.
      Switching the type from `uint64_t` to `uintptr_t` should simply do
      the correct thing on all 32 and 64 bit architectures.
      Reviewers: austin, bgamari, simonmar
      Subscribers: thomie
      Differential Revision: https://phabricator.haskell.org/D1399
      GHC Trac Issues: #11036
  2. 29 Oct, 2015 13 commits
    • Sergei Trofimovich's avatar
      x86 codegen: don't generate location comments · e272ab99
      Sergei Trofimovich authored
      The following source snippet 'module A where x */* y = 42'
      when being compiled with '-g' option emits syntactically
      invalid comment for GNU as:
              .align 8
              .loc 1 3 1 /* */* */
      Fixed by not emitting comments at all. We already suppress
      all asm comments in 'X86/Ppr.hs'.
      Signed-off-by: default avatarSergei Trofimovich <siarheit@google.com>
      Test Plan: added test and check it works
      Reviewers: scpmw, simonmar, austin, bgamari
      Reviewed By: simonmar
      Subscribers: thomie
      Differential Revision: https://phabricator.haskell.org/D1386
      GHC Trac Issues: #10667
    • Ben Gamari's avatar
      Revert "Generate Typeable info at definition sites" · bbaf76f9
      Ben Gamari authored
      This reverts commit bef2f03e.
      This merge was botched
      Also reverts haddock submodule.
    • Ben Gamari's avatar
      Generate Typeable info at definition sites · bef2f03e
      Ben Gamari authored
      This patch implements the idea floated in Trac #9858, namely that we
      should generate type-representation information at the data type
      declaration site, rather than when solving a Typeable constraint.
      However, this turned out quite a bit harder than I expected. I still
      think it's the right thing to do, and it's done now, but it was quite
      a struggle.
      See particularly
       * Note [Grand plan for Typeable] in TcTypeable (which is a new module)
       * Note [The overall promotion story] in DataCon (clarifies existing stuff)
      The most painful bit was that to generate Typeable instances (ie
      TyConRepName bindings) for every TyCon is tricky for types in ghc-prim
       * We need to have enough data types around to *define* a TyCon
       * Many of these types are wired-in
      Also, to minimise the code generated for each data type, I wanted to
      generate pure data, not CAFs with unpackCString# stuff floating about.
      Three perf/compiler tests start to allocate quite a bit more. This isn't
      surprising, because they all allocate zillions of data types, with
      practically no other code, esp. T1969
       * T3294:   GHC allocates 110% more (filed #11030 to track this)
       * T1969:   GHC allocates 30% more
       * T4801:   GHC allocates 14% more
       * T5321FD: GHC allocates 13% more
       * T783:    GHC allocates 12% more
       * T9675:   GHC allocates 12% more
       * T5642:   GHC allocates 10% more
       * T9961:   GHC allocates 6% more
       * T9203:   Program allocates 54% less
      I'm treating this as acceptable. The payoff comes in Typeable-heavy
      Remaining to do
       * I think that "TyCon" and "Module" are over-generic names to use for
         the runtime type representations used in GHC.Typeable. Better might be
         "TrTyCon" and "TrModule". But I have not yet done this
       * Add more info the the "TyCon" e.g. source location where it was
       * Use the new "Module" type to help with Trac Trac #10068
       * It would be possible to generate TyConRepName (ie Typeable
         instances) selectively rather than all the time. We'd need to persist
         the information in interface files. Lacking a motivating reason I have
         not done this, but it would not be difficult.
      As is so often the case, I ended up refactoring more than I intended.
      In particular
       * In TyCon, a type *family* (whether type or data) is repesented by a
           * a algebraic data type (including data/newtype instances) is
             represented by AlgTyCon This wasn't true before; a data family
             was represented as an AlgTyCon. There are some corresponding
             changes in IfaceSyn.
           * Also get rid of the (unhelpfully named) tyConParent.
       * In TyCon define 'Promoted', isomorphic to Maybe, used when things are
         optionally promoted; and use it elsewhere in GHC.
       * Cleanup handling of knownKeyNames
       * Each TyCon, including promoted TyCons, contains its TyConRepName, if
         it has one. This is, in effect, the name of its Typeable instance.
      Requires update of the haddock submodule.
      Differential Revision: https://phabricator.haskell.org/D757
    • Ben Gamari's avatar
      DynFlags: Add (another) missing hunk from D1360 · 40e6214c
      Ben Gamari authored
      What a disaster this merge was.
    • Ben Gamari's avatar
      TcTyDecls: Remove redundant import of Applicative · d25fa862
      Ben Gamari authored and Ben Gamari's avatar Ben Gamari committed
    • Ben Gamari's avatar
    • Thomas Miedema's avatar
      Revert "Build system: don't create mk/are-validating.mk" · fa587316
      Thomas Miedema authored
      This reverts commit aecf4a5f.
      It turns out the Simons are relying on 'mk/are-validating.mk', see
      The workflow they are using is:
        * run ./validate
        * find a bug in the compiler
        * try to fix the bug, running 'make 1' (or 'make 2') repeatedly. Because
          of 'mk/are-validating.mk', this uses the same build settings as validate.
        * continue ./validate (--no-clean)
      I suggested two alternatives:
        A. run 'make 1 Validating=YES' instead of 'make 1'
           Problem: when running `./validate --fast` or `./validate --hpc`
           instead of a normal `./validate`, validate sets ValidateSpeed and
           ValdateHpc in mk/are-validating.mk. You would for example have to run
           'make 1 Validating=YES ValidateSpeed=FAST' instead of 'make 1' to get the
           same build settings as `./validate --fast`, which is entirely too long and
           error prone.
        B. uncomment `#BuildFlavour=validate` in mk/build.mk, and include
            * any other settings you have in build.mk will also get used.
            * the distinction between 'mk/validate.mk' and 'mk/build.mk' becomes less
            * it is easy to forget to include 'mk/validate.mk'.
            * the build system again doesn't have access to the ValidateSpeed and
              ValdateHpc settings set by validate.
      Neither of these two options is entirely satisfactory.
      Reviewers: austin, bgamari
      Differential Revision: https://phabricator.haskell.org/D1383
    • Matthew Pickering's avatar
      Record pattern synonyms · 2a74a64e
      Matthew Pickering authored and Ben Gamari's avatar Ben Gamari committed
      This patch implements an extension to pattern synonyms which allows user
      to specify pattern synonyms using record syntax. Doing so generates
      appropriate selectors and update functions.
      === Interaction with Duplicate Record Fields ===
      The implementation given here isn't quite as general as it could be with
      respect to the recently-introduced `DuplicateRecordFields` extension.
      Consider the following module:
          {-# LANGUAGE DuplicateRecordFields #-}
          {-# LANGUAGE PatternSynonyms #-}
          module Main where
          pattern S{a, b} = (a, b)
          pattern T{a}    = Just a
          main = do
            print S{ a = "fst", b = "snd" }
            print T{ a = "a" }
      In principle, this ought to work, because there is no ambiguity. But at
      the moment it leads to a "multiple declarations of a" error. The problem
      is that pattern synonym record selectors don't do the same name mangling
      as normal datatypes when DuplicateRecordFields is enabled. They could,
      but this would require some work to track the field label and selector
      name separately.
      In particular, we currently represent datatype selectors in the third
      component of AvailTC, but pattern synonym selectors are just represented
      as Avails (because they don't have a corresponding type constructor).
      Moreover, the GlobalRdrElt for a selector currently requires it to have
      a parent tycon.
      (example due to Adam Gundry)
      === Updating Explicitly Bidirectional Pattern Synonyms ===
      Consider the following
      pattern Silly{a} <- [a] where
        Silly a = [a, a]
      f1 = a [5] -- 5
      f2 = [5] {a = 6} -- currently [6,6]
      === Fixing Polymorphic Updates ===
      They were fixed by adding these two lines in `dsExpr`. This might break
      record updates but will be easy to fix.
      + ; let req_wrap = mkWpTyApps (mkTyVarTys univ_tvs)
      - , pat_wrap = idHsWrapper }
      +, pat_wrap = req_wrap }
      === Mixed selectors error ===
      Note [Mixed Record Field Updates]
      Consider the following pattern synonym.
          data MyRec = MyRec { foo :: Int, qux :: String }
          pattern HisRec{f1, f2} = MyRec{foo = f1, qux=f2}
      This allows updates such as the following
          updater :: MyRec -> MyRec
          updater a = a {f1 = 1 }
      It would also make sense to allow the following update (which we
          updater a = a {f1 = 1, qux = "two" } ==? MyRec 1 "two"
      This leads to confusing behaviour when the selectors in fact refer the
      same field.
          updater a = a {f1 = 1, foo = 2} ==? ???
      For this reason, we reject a mixture of pattern synonym and normal
      record selectors in the same update block. Although of course we still
      allow the following.
          updater a = (a {f1 = 1}) {foo = 2}
          > updater (MyRec 0 "str")
          MyRec 2 "str"
    • Ben Gamari's avatar
      Revert "Build system: don't add ALL_HC_OPTS when linking" · a0517889
      Ben Gamari authored and Ben Gamari's avatar Ben Gamari committed
      This reverts commit 9fc2d777.
      This appears to cause interface file issues during rebuilds. Punting
      back to @thomie for further investigation.
    • Thomas Miedema's avatar
      Testsuite: report and error out on unfound tests · 032be43b
      Thomas Miedema authored
      Users are sometimes confused why their test doesn't run. It is usually
      because of a misspelled testname, for example using 'TEST=1234' instead
      of 'TEST=T1234'. After this patch it is hopefully more clear what the
      problem is, showing:
          ERROR: tests not found: ['1234']
      Instead of:
          0 total tests, which gave rise to
          0 test cases, of which
          0 were skipped
      Reviewed by: austin, bgamari
      Differential Revision: https://phabricator.haskell.org/D1388
    • Edward Z. Yang's avatar
    • Erik de Castro Lopo's avatar
      Fix rts/T9579 tests on OS X · ce2416bc
      Erik de Castro Lopo authored
      Sed on OS X does not understand 's/[0-9]\+ bytes/NUM bytes/g' but
      sed on Linux and OS X do understand 's/[0-9]* bytes/NUM bytes/g'.
      Test Plan: Run all rts/T9579 tests on Linux and Mac
      Reviewers: thomie, austin, bgamari
      Differential Revision: https://phabricator.haskell.org/D1394
    • Erik de Castro Lopo's avatar
      rts/Linker.c: Drop support for legacy OS X dyn loading · 776d55c8
      Erik de Castro Lopo authored
      Drop support for old OS X (OS X 10.2 and earlier) dynamic linking.
      10.3 was released in 2003.
      Test Plan: Validate on OS X and Linux.
      Reviewers: bgamari, thomie, austin
      Reviewed By: thomie, austin
      Differential Revision: https://phabricator.haskell.org/D1393
  3. 28 Oct, 2015 4 commits
    • Herbert Valerio Riedel's avatar
      Update `deepseq` submodule · c1e1584a
      Herbert Valerio Riedel authored
      This is done now to prepare for #11026
    • Herbert Valerio Riedel's avatar
      Update haskeline/terminfo submodules · de27bedb
      Herbert Valerio Riedel authored
      This is needed to prepare for #11026 as these updates
      relax the upper bounds on `base` to allow for `base-`
      This update contains no code-changes to terminfo/haskeline yet
    • Simon Peyton Jones's avatar
      Pattern synonyms: swap provided/required · 04b0a73a
      Simon Peyton Jones authored
      This patch swaps the order of provided and required constraints in
      a pattern signature, so it now goes
            pattern P :: req => prov => t1 -> ... tn -> res_ty
      See the long discussion in Trac #10928.
      I think I have found all the places, but I could have missed something
      particularly in comments.
      There is a Haddock changes; so a submodule update.
    • Thomas Miedema's avatar
      Build system: don't add ALL_HC_OPTS when linking · 9fc2d777
      Thomas Miedema authored
      The current scheme in rules/distdir-way-opts.mk is something like this:
        MOST_DIR_HC_OPTS = MOST_HC_OPTS + -odir,-hidir,-stubdir
        ALL_HC_OPTS      = MOST_DIR_HC_OPTS +
      Notice that both ALL_HC_OPTS and GHC_LD_OPTS include MOST_HC_OPTS, and
      currently both got added when linking. Adding MOST_HC_OPTS twice results
      in overly long and hard to decipher command lines (and build logs). This
      commit fixes that.
      Afaik, -odir,-hidir,-stubdir,-hisuf,-osuf,-hcsuf,-spit-objs,-dynamic-too
      are all not needed when linking, so this change should be safe to make.
      GHC_LD_OPTS is for linking, ALL_HC_OPTS is for compiling.
      ALL_HC_OPTS was added to the linking commands in
      37a6a52f, to make sure
      -no-user-package-conf would be in the options list. It still is after
      this change.
      Reviewers: austin, bgamari
      Differential Revision: https://phabricator.haskell.org/D1379
  4. 27 Oct, 2015 16 commits
  5. 26 Oct, 2015 4 commits