Replace fromIntegral with fromInteger or toInteger where possible.

See #637.
This commit is contained in:
Brian Huffman 2019-07-24 13:13:11 -07:00
parent 484f9fc631
commit 2e72a7387c
13 changed files with 17 additions and 17 deletions

View File

@ -461,7 +461,7 @@ evalSetSel e x v =
case x of case x of
TupleSel n _ -> setTuple n TupleSel n _ -> setTuple n
RecordSel n _ -> setRecord n RecordSel n _ -> setRecord n
ListSel ix _ -> setList (fromIntegral ix) ListSel ix _ -> setList (toInteger ix)
where where
bad msg = bad msg =

View File

@ -245,7 +245,7 @@ primLexer cfg cs = run inp Normal
, alexPos i') , alexPos i')
AlexSkip i' _ -> run i' s AlexSkip i' _ -> run i' s
AlexToken i' l act -> AlexToken i' l act ->
let txt = Text.take (fromIntegral l) (input i) let txt = Text.take l (input i)
(mtok,s') = act cfg (alexPos i) txt s (mtok,s') = act cfg (alexPos i) txt s
(rest,pos) = run i' $! s' (rest,pos) = run i' $! s'
in case mtok of in case mtok of

View File

@ -214,15 +214,15 @@ splitQual t =
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
numToken :: Integer -> Text -> TokenT numToken :: Integer -> Text -> TokenT
numToken rad ds = Num (toVal ds') (fromInteger rad) (fromIntegral (T.length ds')) numToken rad ds = Num (toVal ds') (fromInteger rad) (T.length ds')
where where
ds' = T.filter (/= '_') ds ds' = T.filter (/= '_') ds
toVal = T.foldl' (\x c -> rad * x + fromDigit c) 0 toVal = T.foldl' (\x c -> rad * x + fromDigit c) 0
fromDigit :: Char -> Integer fromDigit :: Char -> Integer
fromDigit x' fromDigit x'
| 'a' <= x && x <= 'z' = fromIntegral (10 + fromEnum x - fromEnum 'a') | 'a' <= x && x <= 'z' = toInteger (10 + fromEnum x - fromEnum 'a')
| otherwise = fromIntegral (fromEnum x - fromEnum '0') | otherwise = toInteger (fromEnum x - fromEnum '0')
where x = toLower x' where x = toLower x'
------------------------------------------------------------------------------- -------------------------------------------------------------------------------

View File

@ -96,7 +96,7 @@ noPat pat =
x <- newName x <- newName
r <- getRange r <- getRange
let len = length ps let len = length ps
ty = TSeq (TNum (fromIntegral len)) TWild ty = TSeq (TNum (toInteger len)) TWild
getN a n = sel a x (ListSel n (Just len)) getN a n = sel a x (ListSel n (Just len))
return (pTy r x ty, zipWith getN as [0..] ++ concat dss) return (pTy r x ty, zipWith getN as [0..] ++ concat dss)

View File

@ -184,7 +184,7 @@ getName l = case thing l of
getNum :: Located Token -> Integer getNum :: Located Token -> Integer
getNum l = case thing l of getNum l = case thing l of
Token (Num x _ _) _ -> x Token (Num x _ _) _ -> x
Token (ChrLit x) _ -> fromIntegral (fromEnum x) Token (ChrLit x) _ -> toInteger (fromEnum x)
_ -> panic "[Parser] getNum" ["not a number:", show l] _ -> panic "[Parser] getNum" ["not a number:", show l]
getStr :: Located Token -> String getStr :: Located Token -> String

View File

@ -660,7 +660,7 @@ signedBV :: BV -> Integer
signedBV (BV i x) = signedValue i x signedBV (BV i x) = signedValue i x
signedValue :: Integer -> Integer -> Integer signedValue :: Integer -> Integer -> Integer
signedValue i x = if testBit x (fromIntegral (i-1)) then x - (1 `shiftL` (fromIntegral i)) else x signedValue i x = if testBit x (fromInteger (i-1)) then x - (1 `shiftL` (fromInteger i)) else x
bvSlt :: Integer -> Integer -> Integer -> Eval Value bvSlt :: Integer -> Integer -> Integer -> Eval Value
bvSlt _sz x y = return . VBit $! (x < y) bvSlt _sz x y = return . VBit $! (x < y)
@ -679,7 +679,7 @@ sshrV =
nlam $ \_k -> nlam $ \_k ->
wlam $ \(BV i x) -> return $ wlam $ \(BV i x) -> return $
wlam $ \y -> wlam $ \y ->
let signx = testBit x (fromIntegral (i-1)) let signx = testBit x (fromInteger (i-1))
amt = fromInteger (bvVal y) amt = fromInteger (bvVal y)
negv = (((-1) `shiftL` amt) .|. x) `shiftR` amt negv = (((-1) `shiftL` amt) .|. x) `shiftR` amt
posv = x `shiftR` amt posv = x `shiftR` amt
@ -1481,7 +1481,7 @@ randomV ty seed =
Just gen -> Just gen ->
-- unpack the seed into four Word64s -- unpack the seed into four Word64s
let mask64 = 0xFFFFFFFFFFFFFFFF let mask64 = 0xFFFFFFFFFFFFFFFF
unpack s = fromIntegral (s .&. mask64) : unpack (s `shiftR` 64) unpack s = fromInteger (s .&. mask64) : unpack (s `shiftR` 64)
[a, b, c, d] = take 4 (unpack seed) [a, b, c, d] = take 4 (unpack seed)
in fst $ gen 100 $ seedTFGen (a, b, c, d) in fst $ gen 100 $ seedTFGen (a, b, c, d)

View File

@ -425,7 +425,7 @@ qcCmd qcMode str =
lg2 :: Integer -> Integer lg2 :: Integer -> Integer
lg2 x | x >= 2^(1024::Int) = 1024 + lg2 (x `div` 2^(1024::Int)) lg2 x | x >= 2^(1024::Int) = 1024 + lg2 (x `div` 2^(1024::Int))
| x == 0 = 0 | x == 0 = 0
| otherwise = let valNumD = fromIntegral x :: Double | otherwise = let valNumD = fromInteger x :: Double
in round $ logBase 2 valNumD :: Integer in round $ logBase 2 valNumD :: Integer
prt msg = rPutStr msg >> io (hFlush stdout) prt msg = rPutStr msg >> io (hFlush stdout)

View File

@ -793,7 +793,7 @@ userOptions = mkOptionMap
"Enable type-checker debugging output." $ "Enable type-checker debugging output." $
\case EnvNum n -> do me <- getModuleEnv \case EnvNum n -> do me <- getModuleEnv
let cfg = M.meSolverConfig me let cfg = M.meSolverConfig me
setModuleEnv me { M.meSolverConfig = cfg{ T.solverVerbose = fromIntegral n } } setModuleEnv me { M.meSolverConfig = cfg{ T.solverVerbose = n } }
_ -> return () _ -> return ()
, OptionDescr "core-lint" (EnvBool False) , OptionDescr "core-lint" (EnvBool False)
noCheck noCheck

View File

@ -193,7 +193,7 @@ instance BitWord SBool SWord SInteger where
wordLit n x = svInteger (KBounded False (fromInteger n)) x wordLit n x = svInteger (KBounded False (fromInteger n)) x
integerLit x = svInteger KUnbounded x integerLit x = svInteger KUnbounded x
wordBit x idx = svTestBit x (intSizeOf x - 1 - fromIntegral idx) wordBit x idx = svTestBit x (intSizeOf x - 1 - fromInteger idx)
wordUpdate x idx b = svSymbolicMerge (kindOf x) False b wtrue wfalse wordUpdate x idx b = svSymbolicMerge (kindOf x) False b wtrue wfalse
where where

View File

@ -126,7 +126,7 @@ desugarLiteral fixDec lit =
P.PolyLit _n -> [ ("rep", P.TSeq P.TWild P.TBit) ] P.PolyLit _n -> [ ("rep", P.TSeq P.TWild P.TBit) ]
P.ECString s -> P.ECString s ->
P.ETyped (P.EList [ P.ELit (P.ECNum (fromIntegral (fromEnum c)) P.ETyped (P.EList [ P.ELit (P.ECNum (toInteger (fromEnum c))
P.CharLit) | c <- s ]) P.CharLit) | c <- s ])
(P.TSeq P.TWild (P.TSeq (P.TNum 8) P.TBit)) (P.TSeq P.TWild (P.TSeq (P.TNum 8) P.TBit))

View File

@ -372,7 +372,7 @@ doCheckType ty k =
P.TSeq t1 t2 -> tcon (TC TCSeq) [t1,t2] k P.TSeq t1 t2 -> tcon (TC TCSeq) [t1,t2] k
P.TBit -> tcon (TC TCBit) [] k P.TBit -> tcon (TC TCBit) [] k
P.TNum n -> tcon (TC (TCNum n)) [] k P.TNum n -> tcon (TC (TCNum n)) [] k
P.TChar n -> tcon (TC (TCNum $ fromIntegral $ fromEnum n)) [] k P.TChar n -> tcon (TC (TCNum $ toInteger $ fromEnum n)) [] k
P.TTuple ts -> tcon (TC (TCTuple (length ts))) ts k P.TTuple ts -> tcon (TC (TCTuple (length ts))) ts k

View File

@ -326,7 +326,7 @@ checkHas t sel =
Just len -> Just len ->
case tNoUser n of case tNoUser n of
TCon (TC (TCNum m)) [] TCon (TC (TCNum m)) []
| m == fromIntegral len -> return () | m == toInteger len -> return ()
_ -> reportError $ UnexpectedSequenceShape len n _ -> reportError $ UnexpectedSequenceShape len n
return elT return elT

View File

@ -449,7 +449,7 @@ pIsWidth ty = case tNoUser ty of
tNum :: Integral a => a -> Type tNum :: Integral a => a -> Type
tNum n = TCon (TC (TCNum (fromIntegral n))) [] tNum n = TCon (TC (TCNum (toInteger n))) []
tZero :: Type tZero :: Type
tZero = tNum (0 :: Int) tZero = tNum (0 :: Int)