mirror of
https://github.com/joshuaclayton/unused.git
synced 2024-08-15 15:50:26 +03:00
Follow naming conventions for record fields
This commit is contained in:
parent
67e52ed017
commit
961585ce6e
12
app/Main.hs
12
app/Main.hs
@ -85,8 +85,8 @@ printDirectorySection (dir, ss) = do
|
||||
where
|
||||
allSets = listFromMatchSet ss
|
||||
allResults = fmap snd allSets
|
||||
termLength = return . length . term
|
||||
maxWidth = maximum $ termLength =<< matches =<< allResults
|
||||
termLength = return . length . tmTerm
|
||||
maxWidth = maximum $ termLength =<< trMatches =<< allResults
|
||||
|
||||
printDirectory :: DirectoryPrefix -> IO ()
|
||||
printDirectory (DirectoryPrefix dir) = do
|
||||
@ -97,7 +97,7 @@ printDirectory (DirectoryPrefix dir) = do
|
||||
|
||||
printTermResults :: Int -> (String, TermResults) -> IO ()
|
||||
printTermResults w (_, results) =
|
||||
printMatches w results $ matches results
|
||||
printMatches w results $ trMatches results
|
||||
|
||||
likelihoodColor :: RemovalLikelihood -> Color
|
||||
likelihoodColor High = Red
|
||||
@ -107,13 +107,13 @@ likelihoodColor Low = Green
|
||||
printMatches :: Int -> TermResults -> [TermMatch] -> IO ()
|
||||
printMatches w r ms =
|
||||
forM_ ms $ \m -> do
|
||||
setSGR [SetColor Foreground Dull (likelihoodColor $ removalLikelihood r)]
|
||||
setSGR [SetColor Foreground Dull (likelihoodColor $ trRemovalLikelihood r)]
|
||||
setSGR [SetConsoleIntensity NormalIntensity]
|
||||
putStr $ " " ++ (printf termFormat $ term m)
|
||||
putStr $ " " ++ (printf termFormat $ tmTerm m)
|
||||
setSGR [Reset]
|
||||
setSGR [SetColor Foreground Dull Cyan]
|
||||
setSGR [SetConsoleIntensity FaintIntensity]
|
||||
putStr $ " " ++ path m
|
||||
putStr $ " " ++ tmPath m
|
||||
setSGR [Reset]
|
||||
putStr "\n"
|
||||
where
|
||||
|
@ -17,7 +17,7 @@ parseLines =
|
||||
|
||||
responseFromParse :: Either ParseError [TermMatch] -> ParseResponse
|
||||
responseFromParse =
|
||||
fmap $ Map.fromList . map (second resultsFromMatches) . groupBy term
|
||||
fmap $ Map.fromList . map (second resultsFromMatches) . groupBy tmTerm
|
||||
|
||||
parseTermMatches :: Parser [TermMatch]
|
||||
parseTermMatches = do
|
||||
|
@ -20,17 +20,17 @@ import qualified Data.Map.Strict as Map
|
||||
import Unused.Regex (matchRegex)
|
||||
|
||||
data TermMatch = TermMatch
|
||||
{ term :: String
|
||||
, path :: String
|
||||
, occurrences :: Int
|
||||
{ tmTerm :: String
|
||||
, tmPath :: String
|
||||
, tmOccurrences :: Int
|
||||
} deriving Show
|
||||
|
||||
data TermResults = TermResults
|
||||
{ resultTerm :: String
|
||||
, matches :: [TermMatch]
|
||||
, totalFiles :: Int
|
||||
, totalOccurrences :: Int
|
||||
, removalLikelihood :: RemovalLikelihood
|
||||
{ trTerm :: String
|
||||
, trMatches :: [TermMatch]
|
||||
, trTotalFiles :: Int
|
||||
, trTotalOccurrences :: Int
|
||||
, trRemovalLikelihood :: RemovalLikelihood
|
||||
} deriving Show
|
||||
|
||||
data RemovalLikelihood = High | Medium | Low deriving Show
|
||||
@ -44,18 +44,18 @@ newtype DirectoryPrefix = DirectoryPrefix String deriving (Eq, Show, Ord)
|
||||
resultsFromMatches :: [TermMatch] -> TermResults
|
||||
resultsFromMatches m =
|
||||
calculateLikelihood $ TermResults
|
||||
{ resultTerm = resultTerm' terms
|
||||
, matches = m
|
||||
, totalFiles = totalFiles'
|
||||
, totalOccurrences = totalOccurrences'
|
||||
, removalLikelihood = High
|
||||
{ trTerm = resultTerm terms
|
||||
, trMatches = m
|
||||
, trTotalFiles = totalFiles
|
||||
, trTotalOccurrences = totalOccurrences
|
||||
, trRemovalLikelihood = High
|
||||
}
|
||||
where
|
||||
totalFiles' = length m
|
||||
totalOccurrences' = sum $ fmap occurrences m
|
||||
terms = map term m
|
||||
resultTerm' (x:_) = x
|
||||
resultTerm' _ = ""
|
||||
totalFiles = length m
|
||||
totalOccurrences = sum $ fmap tmOccurrences m
|
||||
terms = map tmTerm m
|
||||
resultTerm (x:_) = x
|
||||
resultTerm _ = ""
|
||||
|
||||
withOneFile :: ParseResponse -> ParseResponse
|
||||
withOneFile = fmap $ Map.filterWithKey (const oneFile)
|
||||
@ -64,35 +64,35 @@ withOneOccurrence :: ParseResponse -> ParseResponse
|
||||
withOneOccurrence = fmap $ Map.filterWithKey (const oneOccurence)
|
||||
|
||||
oneOccurence :: TermResults -> Bool
|
||||
oneOccurence = (== 1) . totalOccurrences
|
||||
oneOccurence = (== 1) . trTotalOccurrences
|
||||
|
||||
oneFile :: TermResults -> Bool
|
||||
oneFile = (== 1) . totalFiles
|
||||
oneFile = (== 1) . trTotalFiles
|
||||
|
||||
isClassOrModule :: TermResults -> Bool
|
||||
isClassOrModule = matchRegex "^[A-Z]" . resultTerm
|
||||
isClassOrModule = matchRegex "^[A-Z]" . trTerm
|
||||
|
||||
railsSingleOkay :: TermResults -> Bool
|
||||
railsSingleOkay r =
|
||||
foldl1 (&&) [isClassOrModule r, oneFile r, oneOccurence r, (controller || helper || migration)]
|
||||
where
|
||||
controller = (matchRegex "^app/controllers/" singlePath) && (matchRegex "Controller$" $ resultTerm r)
|
||||
helper = (matchRegex "^app/helpers/" singlePath) && (matchRegex "Helper$" $ resultTerm r)
|
||||
controller = (matchRegex "^app/controllers/" singlePath) && (matchRegex "Controller$" $ trTerm r)
|
||||
helper = (matchRegex "^app/helpers/" singlePath) && (matchRegex "Helper$" $ trTerm r)
|
||||
migration = matchRegex "^db/migrate/" singlePath
|
||||
singlePath = path' $ fmap path $ matches r
|
||||
path' (x:_) = x
|
||||
path' [] = ""
|
||||
singlePath = path $ fmap tmPath $ trMatches r
|
||||
path (x:_) = x
|
||||
path [] = ""
|
||||
|
||||
elixirSingleOkay :: TermResults -> Bool
|
||||
elixirSingleOkay r =
|
||||
foldl1 (&&) [isClassOrModule r, oneFile r, oneOccurence r, (view || test || migration)]
|
||||
where
|
||||
migration = matchRegex "^priv/repo/migrations/" singlePath
|
||||
view = (matchRegex "^web/views/" singlePath) && (matchRegex "View$" $ resultTerm r)
|
||||
test = (matchRegex "^test/" singlePath) && (matchRegex "Test$" $ resultTerm r)
|
||||
singlePath = path' $ fmap path $ matches r
|
||||
path' (x:_) = x
|
||||
path' [] = ""
|
||||
view = (matchRegex "^web/views/" singlePath) && (matchRegex "View$" $ trTerm r)
|
||||
test = (matchRegex "^test/" singlePath) && (matchRegex "Test$" $ trTerm r)
|
||||
singlePath = path $ fmap tmPath $ trMatches r
|
||||
path (x:_) = x
|
||||
path [] = ""
|
||||
|
||||
listFromMatchSet :: TermMatchSet -> [(String, TermResults)]
|
||||
listFromMatchSet =
|
||||
@ -106,9 +106,9 @@ responseForPath :: DirectoryPrefix -> TermMatchSet -> TermMatchSet
|
||||
responseForPath s =
|
||||
filterVByPath . filterKVByPath
|
||||
where
|
||||
filterVByPath = Map.map (resultsFromMatches . filter (((==) s) . fileNameGrouping . path) . matches)
|
||||
filterVByPath = Map.map (resultsFromMatches . filter (((==) s) . fileNameGrouping . tmPath) . trMatches)
|
||||
filterKVByPath = Map.filterWithKey (\_ a -> s `elem` allPaths a)
|
||||
allPaths = fmap (fileNameGrouping . path) . matches
|
||||
allPaths = fmap (fileNameGrouping . tmPath) . trMatches
|
||||
|
||||
fileNameGrouping :: String -> DirectoryPrefix
|
||||
fileNameGrouping =
|
||||
@ -118,15 +118,15 @@ fileNameGrouping =
|
||||
|
||||
directoriesForGrouping :: TermMatchSet -> [DirectoryPrefix]
|
||||
directoriesForGrouping =
|
||||
uniqueValues . Map.map (fmap (fileNameGrouping . path) . matches)
|
||||
uniqueValues . Map.map (fmap (fileNameGrouping . tmPath) . trMatches)
|
||||
where
|
||||
uniqueValues = sort . nub . concat . Map.elems
|
||||
|
||||
calculateLikelihood :: TermResults -> TermResults
|
||||
calculateLikelihood r =
|
||||
r { removalLikelihood = newLikelihood }
|
||||
r { trRemovalLikelihood = newLikelihood }
|
||||
where
|
||||
baseScore = totalOccurrences r
|
||||
baseScore = trTotalOccurrences r
|
||||
railsScore = if railsSingleOkay r then 5 else 0
|
||||
elixirScore = if elixirSingleOkay r then 5 else 0
|
||||
totalScore = baseScore + railsScore + elixirScore
|
||||
|
Loading…
Reference in New Issue
Block a user