PrintAs.hs revision ad306df140215d8fb88d14bbb7d685011e0f770b
{- |
Module : $Header$
Description : print the abstract syntax of FreeCAD terms
Copyright : (c) Robert Savu and Uni Bremen 2011
License : GPLv2 or higher, see LICENSE.txt
Maintainer : Robert.Savu@dfki.de
Stability : experimental
Portability : portable
Printing of the abstract syntax of FreeCAD terms
-}
module FreeCAD.PrintAs where
import FreeCAD.As
import Common.DocUtils
import Common.Doc
import Common.Id
-- | Pretty printing 'Double'
instance Pretty Double where
pretty = sidDoc . mkSimpleId . show
instance Pretty Vector3 where
pretty v = pretty (x v, y v, z v)
instance Pretty Matrix33 where
pretty m = vcat [lparen <+> rows, rparen] where
rows = vcat [row1, row2, row3]
row a b c = sepByCommas $ map pretty [a m, b m, c m]
row1 = row a11 a12 a13
row2 = row a21 a22 a23
row3 = row a31 a32 a33
instance Pretty Vector4 where
pretty v = parens $ sepByCommas $ map pretty [q0 v, q1 v, q2 v, q3 v]
instance Pretty Placement where
pretty p = brackets $sepBySemis [pretty $position p, pretty $orientation p]
printBO:: BaseObject -> Doc
printBO (Box h w l) = text "Box" <+> (vcat[hrow, wrow, lrow]) where
hrow = hcat [ text "Height ", pretty h]
wrow = hcat [ text "Width ", pretty w]
lrow = hcat [ text "Length ", pretty l]
printBO (Cylinder a h r) = text "Cylinder" <+> (vcat[arow, hrow, rrow]) where
arow = hcat [ text "Angle ", pretty a]
hrow = hcat [ text "Heigth ", pretty h]
rrow = hcat [ text "Radius ", pretty r]
printBO (Sphere a1 a2 a3 r) = text "Sphere" <+> (vcat[a1row, a2row, a3row, rrow]) where
a1row = hcat [ text "Angle1 ", pretty a1]
a2row = hcat [ text "Angle2 ", pretty a2]
a3row = hcat [ text "Angle3 ", pretty a3]
rrow = hcat [ text "Radius ", pretty r]
printBO (Cone a r1 r2 h) = text "Cone" <+> (vcat[arow, brow, hrow, rrow]) where
arow = hcat [ text "Angle ", pretty a]
brow = hcat [ text "Radius1 ", pretty r1]
hrow = hcat [ text "Radius2 ", pretty r2]
rrow = hcat [ text "Heigth ", pretty h]
printBO (Torus t1 t2 t3 t4 t5) = text "Torus" <+> (vcat[t1r, t2r, t3r, t4r, t5r])
where
t1r = hcat [ text "Angle1 ", pretty t1]
t2r = hcat [ text "Angle1 ", pretty t2]
t3r = hcat [ text "Angle1 ", pretty t3]
t4r = hcat [ text "Radius1 ", pretty t4]
t5r = hcat [ text "Radius2 ", pretty t5]
printBO (Line a) = text "Line" <+> hcat [ text "Length ", pretty a]
printBO (Circle a h r) = text "Circle" <+> (vcat[arow, hrow, rrow]) where
arow = hcat [ text "sAngle ", pretty a]
hrow = hcat [ text "eAngle ", pretty h]
rrow = hcat [ text "Radius ", pretty r]
printBO (Rectangle h w) = text "Rectangle" <+> (vcat[hrow, wrow]) where
hrow = hcat [ text "Heigth ", pretty h]
wrow = hcat [ text "Width ", pretty w]
instance Pretty BaseObject where
pretty bo = printBO bo
printObject:: Object -> Doc
printObject (BaseObject bo) = pretty bo
printObject ( Cut eo1 eo2) = text "Cut" <+> vcat[pretty eo1, pretty eo2]
printObject ( Common eo1 eo2) = text "Common" <+> vcat[pretty eo1, pretty eo2]
printObject ( Fusion eo1 eo2) = text "Fusion" <+> vcat[pretty eo1, pretty eo2]
printObject ( Section eo1 eo2) = text "Section" <+> vcat[pretty eo1, pretty eo2]
instance Pretty Object where
pretty o = printObject o
printEO:: ExtendedObject -> Doc
printEO (Placed po) = pretty po
printEO (Ref s) = text s
instance Pretty ExtendedObject where
pretty eo = printEO eo
printPO:: PlacedObject -> Doc
printPO (PlacedObject p o) = vcat[pretty o, text "place" <+> pretty p]
instance Pretty PlacedObject where
pretty po = printPO po
instance Pretty NamedObject where
pretty no =
lbrack $+$ space <+> hcat[doubleQuotes $pretty $name no, colon, space, pretty $object no]
$+$ rbrack
printDoc:: Document -> Doc
printDoc a = vcat $ map pretty a