diff options
| author | Sylvain Henry <hsyl20@gmail.com> | 2018-06-15 16:23:53 -0400 | 
|---|---|---|
| committer | Ben Gamari <ben@smart-cactus.org> | 2018-06-15 16:23:54 -0400 | 
| commit | fe770c211631e7b4c9b0b1e88ef9b6046c6585ef (patch) | |
| tree | e6a061a92d8d0d71d40c699982ee471627d816e0 /compiler/codeGen | |
| parent | 42f3b53b5bc4674e41f16de08094821fe1aaec00 (diff) | |
| download | haskell-fe770c211631e7b4c9b0b1e88ef9b6046c6585ef.tar.gz | |
Built-in Natural literals in Core
Add support for built-in Natural literals in Core.
- Replace MachInt,MachWord, LitInteger, etc. with a single LitNumber
  constructor with a LitNumType field
- Support built-in Natural literals
- Add desugar warning for negative literals
- Move Maybe(..) from GHC.Base to GHC.Maybe for module dependency
  reasons
This patch introduces only a few rules for Natural literals (compared
to Integer's rules). Factorization of the built-in rules for numeric
literals will be done in another patch as this one is already big to
review.
Test Plan:
  validate
  test build with integer-simple
Reviewers: hvr, bgamari, goldfire, Bodigrim, simonmar
Reviewed By: bgamari
Subscribers: phadej, simonpj, RyanGlScott, carter, hsyl20, rwbarton,
thomie
GHC Trac Issues: #14170, #14465
Differential Revision: https://phabricator.haskell.org/D4212
Diffstat (limited to 'compiler/codeGen')
| -rw-r--r-- | compiler/codeGen/StgCmmCon.hs | 2 | ||||
| -rw-r--r-- | compiler/codeGen/StgCmmUtils.hs | 11 | 
2 files changed, 6 insertions, 7 deletions
| diff --git a/compiler/codeGen/StgCmmCon.hs b/compiler/codeGen/StgCmmCon.hs index 8dadb4ede7..f2287e0fbd 100644 --- a/compiler/codeGen/StgCmmCon.hs +++ b/compiler/codeGen/StgCmmCon.hs @@ -198,7 +198,7 @@ because they don't support cross package data references well.  buildDynCon' dflags platform binder _ _cc con [arg]    | maybeIntLikeCon con    , platformOS platform /= OSMinGW32 || not (positionIndependent dflags) -  , NonVoid (StgLitArg (MachInt val)) <- arg +  , NonVoid (StgLitArg (LitNumber LitNumInt val _)) <- arg    , val <= fromIntegral (mAX_INTLIKE dflags) -- Comparisons at type Integer!    , val >= fromIntegral (mIN_INTLIKE dflags) -- ...ditto...    = do  { let intlike_lbl   = mkCmmClosureLabel rtsUnitId (fsLit "stg_INTLIKE") diff --git a/compiler/codeGen/StgCmmUtils.hs b/compiler/codeGen/StgCmmUtils.hs index 94013f5c6d..99fa550b83 100644 --- a/compiler/codeGen/StgCmmUtils.hs +++ b/compiler/codeGen/StgCmmUtils.hs @@ -94,10 +94,10 @@ cgLit other_lit   = do dflags <- getDynFlags  mkSimpleLit :: DynFlags -> Literal -> CmmLit  mkSimpleLit dflags (MachChar   c)    = CmmInt (fromIntegral (ord c)) (wordWidth dflags)  mkSimpleLit dflags MachNullAddr      = zeroCLit dflags -mkSimpleLit dflags (MachInt i)       = CmmInt i (wordWidth dflags) -mkSimpleLit _      (MachInt64 i)     = CmmInt i W64 -mkSimpleLit dflags (MachWord i)      = CmmInt i (wordWidth dflags) -mkSimpleLit _      (MachWord64 i)    = CmmInt i W64 +mkSimpleLit dflags (LitNumber LitNumInt i _)    = CmmInt i (wordWidth dflags) +mkSimpleLit _      (LitNumber LitNumInt64 i _)  = CmmInt i W64 +mkSimpleLit dflags (LitNumber LitNumWord i _)   = CmmInt i (wordWidth dflags) +mkSimpleLit _      (LitNumber LitNumWord64 i _) = CmmInt i W64  mkSimpleLit _      (MachFloat r)     = CmmFloat r W32  mkSimpleLit _      (MachDouble r)    = CmmFloat r W64  mkSimpleLit _      (MachLabel fs ms fod) @@ -529,8 +529,7 @@ emitCmmLitSwitch scrut  branches deflt = do      -- We find the necessary type information in the literals in the branches      let signed = case head branches of -                    (MachInt _, _) ->   True -                    (MachInt64 _, _) -> True +                    (LitNumber nt _ _, _) -> litNumIsSigned nt                      _ -> False      let range | signed    = (tARGET_MIN_INT dflags, tARGET_MAX_INT dflags) | 
