Учитывая следующий код:Как удалить шаблон при записи перегруженных строк?
{-# LANGUAGE OverloadedStrings #-}
newtype Firstname = Firstname String deriving (Eq, Show)
instance IsString Firstname where fromString = Firstname
newtype Lastname = Lastname String deriving (Eq, Show)
instance IsString Lastname where fromString = Lastname
data Person = Person { firstname :: Firstname, lastname :: Lastname, age :: Int } deriving Show
Я хотел бы, чтобы удалить шаблонного вокруг создания строго типизированных строк. Можно ли использовать Template Haskell (или некоторые другие средства) для достижения этого?
например что-то вроде:
{-# LANGUAGE OverloadedStrings, TemplateHaskell #-}
$(strongString ''Firstname)
$(strongString ''Lastname)
data Person = Person { firstname :: Firstname, lastname :: Lastname, age :: Int } deriving Show