Я готовлюсь к экзамену Haskell через 2 недели. Сейчас я делаю несколько упражнений, но я застрял на этом.
Реализуйте функцию
choosing
, которая получает 2 линзы и должна возвращать новую линзу, которая работает сEither
значениями.
Мне дан этот код:
type Lens s a = forall f . Functor f => (a -> f a) -> s -> f s
--------------------------------------------------------------
-- Lens s1 a :: Functor f => a -> f a -> s1 -> f s1
-- Lens s2 a :: Functor f => a -> f a -> s2 -> f s2
-- Lens (Either s1 s2) a :: Functor f => a -> f a -> (Either s1 s2) -> f (Either s1 s2)
--------------------------------------------------------------
choosing :: Lens s1 a -> Lens s2 a -> Lens (Either s1 s2) a
choosing lns1 lns2 = undefined
Теперь я полностью застрял. Я думаю, что я должен использовать fmap для решения этой проблемы, но я не знаю, как объединить эти 2 объектива.
Итак, с помощью @shang и @klappvisor я нашел полный ответ на этот вопрос:
choosing :: Lens s1 a -> Lens s2 a -> Lens (Either s1 s2) a
choosing lns1 lns2 = (\func x -> case x of
Left value -> (\z -> Left $ set lns1 z value) <$> (func (view lns1 value))
Right value -> (\z -> Right $ set lns2 z value) <$> (func (view lns2 value)))