169 похожих чатов

Насколько моя реализация Exercise 1 плохая? data MessageType = Info

| Warning
| Error Int
deriving (Show, Eq)

type TimeStamp = Int

data LogMessage
= LogMessage
MessageType
TimeStamp
String
| Unknown String
deriving (Show, Eq)

parseMessage :: String -> LogMessage
parseMessage line = if isNothing msgType || isNothing timeStamp || isNothing msg then Unknown line else LogMessage (fromJust msgType) (fromJust timeStamp) (fromJust msg)
where
arr = splitOneOf " " line
msgType :: Maybe MessageType
| head arr == "I" = Just Info
| head arr == "W" = Just Warning
| head arr == "E" = Just $ Error (read $ arr !! 1 :: Int)
| otherwise = Nothing
timeStamp :: Maybe TimeStamp = readMaybe $ arr !! (if head arr == "E" then 2 else 1) :: Maybe Int
msg :: Maybe String = if isNothing msgType || isNothing timeStamp then Nothing else Just $ unwords (if head arr == "E" then tail $ tail $ tail arr else tail $ tail arr)

10 ответов

16 просмотров

Ну странный вопрос, тебе по какой шкале? Что даст тебе цифра?

=-? Автор вопроса
Danil Berestov
Ну странный вопрос, тебе по какой шкале? Что даст ...

Качество кода, прошу указать на места, где можно сделать лучше/явно сделано далеко не лучшим образом

= ?
Качество кода, прошу указать на места, где можно с...

Ну так и надо. Так-то на изначальный твой вопрос можно ответить "средне плохо" или "очень плохо", тока толку от этого нет

как по мне это решение очень неидиоматично - сила Хаскелля в том, что можно легко проверить формат данных и скомбинировать их в нужный результат, а тут используется более императивный подход, аля "возьми элемент номер 1, это код ошибки"

=-? Автор вопроса

parseMessage :: String -> LogMessage parseMessage line = case parse1 $ splitOneOf " " line of (Just a) -> a _ -> Unknown line where parse1 ("I":xs) = parse2 Info xs parse1 ("W":xs) = parse2 Warning xs parse1 ("E":(x:xs)) = case readMaybe $ x :: Maybe Int of (Just a) -> parse2 (Error $ a) xs _ -> Nothing parse1 (_:xs) = Nothing parse2 msgType (x:xs) = case readMaybe x of (Just a) -> Just $ LogMessage msgType a (unwords xs) _ -> Nothing parse2 _ [] = Nothing Я работаю в правильном направлении?

= ?
parseMessage :: String -> LogMessage parseMessage ...

да, имена бы ещё дать осмысленные

= ?
parseMessage :: String -> LogMessage parseMessage ...

Обычно вместо небазовой splitOneOf " " используют обычную words из Prelude. Но она разделяет строку не только по пробелам, а по любым пробельным символам, так что это не совсем одно и то же.

= ?
parseMessage :: String -> LogMessage parseMessage ...

скобки вокрук всего паттерна лишние (Just a) -> _ Just a -> _

= ?
parseMessage :: String -> LogMessage parseMessage ...

конс правоассоциативен parse1 ("E":(x:xs)) = _ parse1 ("E" : x : xs) = _

= ?
parseMessage :: String -> LogMessage parseMessage ...

доллар с одной переменной не нужен readMaybe $ x readMaybe x (Error $ a) (Error a)

Похожие вопросы

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us 👉We offer Interview Support :-for a low cost variety of tech...
Rambabu Nallamilli
3
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
Книга Юрова В.И пойдёт для обучения?
Botsman
24
Hello experts, Could someone kindly tell me how to run vacuum inside a plpgsql function? If you have any link please share. Thank you
Amol Palav
10
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Приветствую, уважаемые граждане! Пытаюсь создать var A: array[1_000_000_000, float] При компиляции ошибка. Машина с 8 ГБ оперативной памяти. И я понимаю, что А будет занимат...
|
5
@rouse_79 можно ли как-то отловить событие для модального окна, когда пытаются ткнуть в родительское?
Hemul GM
11
Карта сайта