на каждый примитив есть три функции, которые читают данные в разном порядке (от старшего к младшему, от младшему к старшему)
Мне нужно распарсить бинарные данные, но проблема в том, что об порядке байтов можно узнать, прочитав первый байт. (Условно, если там ноль, то порядок байтов LE, иначе BE). Но тогда бы пришлось писать две функции для разного порядка байт. Тогда как быть?
Я лишь придумал что-то подобное
data Endianness = LE | BE
getWord32 :: Endianness -> Get Word32
getWord32 LE = getWord32le
getWord32 BE = getWord32be
похоже на костыль
Но кто-то же пишет эти данные, те что нужно прочитать? В доках порядок байт посмотреть? У автора спросить?
ну такое может быть, что один файл в LE, другой в BE. но первый байт (условно) в файле показывает, какой порядок байт
по-моему, не похоже на костыль. у вас в задаче способ чтения зависит от первого байта и в коде то же самое. в чём проблема?
Обсуждают сегодня