data Foo = Foo {
_bar :: Map String Integer
} deriving (Eq, Ord, Read, Show, Data, Typeable)
$(deriveSafeCopy 0 'base 'Foo)
$(makeLenses ''Foo)
Учитывая приведенный выше код, у меня сложилось впечатление, что это должно быть возможно:
addEntry :: String -> Update Foo ()
addEntry s = zoom bar $ modify $ insert s 0
Но GHC будет жаловаться на:
src/Backend.hs:39:20:
No instance for (Functor
(Control.Lens.Internal.Zoom.Zoomed (Update Foo) ()))
Любые идеи?