Я не уверен, что я не обращаюсь. Предположим, у меня есть функция, которая преобразует целое число в строку. Назовите это converter
.
Теперь, чтобы преобразовать целое число позиции в строку, я просто вызываю converter
. Чтобы преобразовать отрицательное целое число в строку, я добавляю -
к вызову converter
.
Это мой код:
converter :: Integer -> String
converter x
| x == 0 = "0"
| x == 1 = "1"
| x == 2 = "2"
| x == 3 = "3"
| x == 4 = "4"
| x == 5 = "5"
| x == 6 = "6"
| x == 7 = "7"
| x == 8 = "8"
| x == 9 = "9"
| x > 9 = z
where
(a, b) = divMod x 10
z = (converter a) ++ (converter b)
negOrPosConverter :: NegOrPosInteger -> String
negOrPosConverter (ActualInt x)
| x >= 0 = converter x
| x < 0 = "-" ++ (converter x)
Когда я запускаю код и пытаюсь negOrPosConverter (ActualInt (-200))
я получаю эту ошибку:
"-*** Exception: theConverter.hs:(19,1)-(27,32): Non-exhaustive patterns in function converter
Есть идеи, почему?