Skip to content

Instantly share code, notes, and snippets.

@masaeedu
Created July 27, 2017 21:37
Show Gist options
  • Save masaeedu/d5c0c311eff6c61dc518eb7215375f56 to your computer and use it in GitHub Desktop.
Save masaeedu/d5c0c311eff6c61dc518eb7215375f56 to your computer and use it in GitHub Desktop.
newtype EmployeeVisitor r = EmployeeVisitor { visit :: Employee -> r }
data Employee = PermanentEmployee | Contractor
xmlvisitor :: EmployeeVisitor String
xmlvisitor = EmployeeVisitor { visit = visitEmp }
where visitEmp PermanentEmployee = "<employee />"
visitEmp Contractor = "<contractor />"
class VisitableEmployee e where
accept :: e -> EmployeeVisitor r -> r
instance VisitableEmployee Employee where
accept e v = visit v e
main = do putStrLn (accept PermanentEmployee xmlvisitor)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment