powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Программирование [игнор отключен] [закрыт для гостей] / Haskell, вопрос по монадам
3 сообщений из 3, страница 1 из 1
Haskell, вопрос по монадам
    #37439335
GrasQtR
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Приветствую всех.

Разбираюсь с Parsec вот по этому туториалу. Возник вопрос в следующем куске кода:
Код: plaintext
1.
2.
3.
4.
5.
6.
spaces :: Parser ()
 spaces = skipMany1 space

readExpr input = case parse (spaces >> symbol) "lisp" input of
     Left err -> "No match: " ++ show err
     Right val -> "Found value"
Непонятен принцип работы конструкции (spaces >> symbol), как она работает? Т.е. парсер прогоняет текст, удаляя все пробелы, затем ищет другие символы, или как-то по другому?
...
Рейтинг: 0 / 0
Haskell, вопрос по монадам
    #37439892
Фотография ZyK_BotaN
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
GrasQtRПриветствую всех.

Разбираюсь с Parsec вот по этому туториалу. Возник вопрос в следующем куске кода:
Код: plaintext
1.
2.
3.
4.
5.
6.
spaces :: Parser ()
 spaces = skipMany1 space

readExpr input = case parse (spaces >> symbol) "lisp" input of
     Left err -> "No match: " ++ show err
     Right val -> "Found value"
Непонятен принцип работы конструкции (spaces >> symbol), как она работает? Т.е. парсер прогоняет текст, удаляя все пробелы, затем ищет другие символы, или как-то по другому?

(>>) - биндит две монады в одну.

было две монады - пробелы и символ
получили новую монаду пробелы_символ.
...
Рейтинг: 0 / 0
Haskell, вопрос по монадам
    #37443414
Фотография ZyK_BotaN
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ZyK_BotaNGrasQtRПриветствую всех.

Разбираюсь с Parsec вот по этому туториалу. Возник вопрос в следующем куске кода:
Код: plaintext
1.
2.
3.
4.
5.
6.
spaces :: Parser ()
 spaces = skipMany1 space

readExpr input = case parse (spaces >> symbol) "lisp" input of
     Left err -> "No match: " ++ show err
     Right val -> "Found value"
Непонятен принцип работы конструкции (spaces >> symbol), как она работает? Т.е. парсер прогоняет текст, удаляя все пробелы, затем ищет другие символы, или как-то по другому?

(>>) - биндит две монады в одну.

было две монады - пробелы и символ
получили новую монаду пробелы_символ.
соврал я. вот сейчас читал про это, результат первой монады игнорируется, а возвращается результат второй.

получается, что распарешнные пробелы игнорируем, а возвращаем распаршенный symbol.
...
Рейтинг: 0 / 0
3 сообщений из 3, страница 1 из 1
Форумы / Программирование [игнор отключен] [закрыт для гостей] / Haskell, вопрос по монадам
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]