[commit: ghc] wip/nfs-locking: Document and test encode/decodeModule. (5e32c91)
git at git.haskell.org
git at git.haskell.org
Fri Oct 27 00:04:46 UTC 2017
Repository : ssh://git@git.haskell.org/ghc
On branch : wip/nfs-locking
Link : http://ghc.haskell.org/trac/ghc/changeset/5e32c9147ba23b886ae6154200fc7961481f4bd9/ghc
>---------------------------------------------------------------
commit 5e32c9147ba23b886ae6154200fc7961481f4bd9
Author: Andrey Mokhov <andrey.mokhov at gmail.com>
Date: Sat Feb 20 22:40:41 2016 +0000
Document and test encode/decodeModule.
See #197, #210.
>---------------------------------------------------------------
5e32c9147ba23b886ae6154200fc7961481f4bd9
src/Base.hs | 7 +++++--
src/Rules/Selftest.hs | 14 ++++++++++++++
2 files changed, 19 insertions(+), 2 deletions(-)
diff --git a/src/Base.hs b/src/Base.hs
index 7d63fa0..7217834 100644
--- a/src/Base.hs
+++ b/src/Base.hs
@@ -98,13 +98,16 @@ versionToInt s = major * 1000 + minor * 10 + patch
-- | Given a module name extract the directory and file name, e.g.:
--
--- > decodeModule "Data.Functor.Identity" = ("Data/Functor/", "Identity")
+-- > decodeModule "Data.Functor.Identity" == ("Data/Functor/", "Identity")
+-- > decodeModule "Prelude" == ("./", "Prelude")
decodeModule :: String -> (FilePath, String)
decodeModule = splitFileName . replaceEq '.' '/'
-- | Given the directory and file name find the corresponding module name, e.g.:
--
--- > encodeModule "Data/Functor/" "Identity.hs" = "Data.Functor.Identity"
+-- > encodeModule "Data/Functor/" "Identity.hs" == "Data.Functor.Identity"
+-- > encodeModule "./" "Prelude" == "Prelude"
+-- > uncurry encodeModule (decodeModule name) == name
encodeModule :: FilePath -> String -> String
encodeModule dir file = replaceEq '/' '.' $ dir -/- takeBaseName file
diff --git a/src/Rules/Selftest.hs b/src/Rules/Selftest.hs
index 70a4023..c156b44 100644
--- a/src/Rules/Selftest.hs
+++ b/src/Rules/Selftest.hs
@@ -24,6 +24,7 @@ selftestRules =
testWays
testChunksOfSize
testMatchVersionedFilePath
+ testModuleNames
testWays :: Action ()
testWays = do
@@ -54,3 +55,16 @@ testMatchVersionedFilePath = do
matchVersionedFilePath prefix suffix (prefix ++ version ++ suffix)
where
versions = listOf . elements $ '-' : '.' : ['0'..'9']
+
+testModuleNames :: Action ()
+testModuleNames = do
+ putBuild $ "==== Encode/decode module name"
+ test $ encodeModule "Data/Functor/" "Identity.hs" == "Data.Functor.Identity"
+ test $ encodeModule "./" "Prelude" == "Prelude"
+
+ test $ decodeModule "Data.Functor.Identity" == ("Data/Functor/", "Identity")
+ test $ decodeModule "Prelude" == ("./", "Prelude")
+
+ test $ forAll names $ \n -> uncurry encodeModule (decodeModule n) == n
+ where
+ names = intercalate "." <$> listOf1 (listOf1 $ elements "abcABC123_'")
More information about the ghc-commits
mailing list