Skip to content

Commit

Permalink
Refactor Ch4 largestSmallest using pattern matching to improve readab…
Browse files Browse the repository at this point in the history
…ility (#390)

Related #340
  • Loading branch information
klarkc authored Oct 3, 2021
1 parent 511dd50 commit c80b391
Showing 1 changed file with 10 additions and 19 deletions.
29 changes: 10 additions & 19 deletions exercises/chapter4/test/no-peeking/Solutions.purs
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,10 @@ module Test.NoPeeking.Solutions where

import Prelude
import Control.MonadZero (guard)
import Data.Array (catMaybes, cons, filter, find, head, last, length, nub, null, tail, (..))
import Data.Array (cons, filter, head, length, null, tail, (..), (:))
import Data.Foldable (foldl)
import Data.Int (rem, quot)
import Data.Maybe (Maybe(..), fromMaybe, maybe)
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Path (Path, filename, isDirectory, ls, size)
import Data.String.Common (split)
import Data.String.Pattern (Pattern(..))
import Data.Tuple (Tuple(..))
import Test.Examples

Expand Down Expand Up @@ -111,17 +108,11 @@ whereIs path fileName = head $ do
pure path'

largestSmallest :: Path -> Array Path
largestSmallest path =
let files = onlyFiles path
maybeSizes = map size files
maybeMax = foldl (outlier (>)) Nothing maybeSizes
maybeMin = foldl (outlier (<)) Nothing maybeSizes
in catMaybes $ map (findFileBySize files) $ nub $ [maybeMax, maybeMin]
where
outlier :: (Int -> Int -> Boolean) -> Maybe Int -> Maybe Int -> Maybe Int
outlier criteria Nothing Nothing = Nothing
outlier criteria (Just x) Nothing = Just x
outlier criteria Nothing (Just x) = Just x
outlier criteria (Just x1) (Just x2) = if criteria x1 x2 then Just x1 else Just x2
findFileBySize :: Array Path -> Maybe Int -> Maybe Path
findFileBySize files maybeSize = find (\file -> size file == maybeSize) files
largestSmallest path = foldl loop [] (onlyFiles path) where
loop :: Array Path -> Path -> Array Path
loop [largest, smallest] current | size current < size smallest = [largest, current]
| size current > size largest = [current, smallest]
| otherwise = [largest, smallest]
loop [last] current | size current < size last = [current, last]
| otherwise = [last, current]
loop arr current = current : arr

0 comments on commit c80b391

Please sign in to comment.