DIAGRAM: add maybeDiag convenience function

This commit is contained in:
hasufell 2014-10-10 15:40:56 +02:00
parent 5d5d0b7643
commit cb7d5269a0
No known key found for this signature in database
GPG Key ID: 220CD1C5BDEED020
1 changed files with 13 additions and 4 deletions

View File

@ -92,6 +92,15 @@ yuD :: DiagProp -> Double
yuD = snd . dY
-- |Returns the specified diagram if True is passed,
-- otherwise returns the empty diagram. This is just for convenience
-- to avoid if else constructs.
maybeDiag :: Bool -> Diag -> Diag
maybeDiag b d
| b = d
| otherwise = mempty
-- |Creates a Diagram that shows the coordinates from the points
-- as dots. The points and thickness of the dots can be controlled
-- via DiagProp.
@ -253,17 +262,17 @@ diag :: DiagProp -> [PT] -> Diagram Cairo R2
diag p = case alg p of
0 ->
mkDiag
(mconcat [if ct p then coordPointsText else mempty,
(mconcat [maybeDiag (ct p) coordPointsText,
coordPoints, xAxis, yAxis,
(if gd p then grid else mempty),whiteRectB])
maybeDiag (gd p) grid, whiteRectB])
p
1 ->
mkDiag
(mconcat
[if ct p then convexHullPointsText else mempty,
[maybeDiag (ct p) convexHullPointsText,
convexHullPoints, convexHullLines,
coordPoints, xAxis, yAxis,
(if gd p then grid else mempty), whiteRectB])
maybeDiag (gd p) grid, whiteRectB])
p
_ -> mempty