this post was submitted on 02 Jul 2023
197 points (94.6% liked)
Programmer Humor
19691 readers
85 users here now
Welcome to Programmer Humor!
This is a place where you can post jokes, memes, humor, etc. related to programming!
For sharing awful code theres also Programming Horror.
Rules
- Keep content in english
- No advertisements
- Posts must be related to programming or programmer topics
founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
Hmm no, I can't say that I've ever writen code like that. For one, it might be better to use
loop :: (a -> Either a b) -> a -> b
instead so that you don't have to sort through the result afterwards withfind
.I'm not sure exactly what you're trying to do, but maybe using the
State
monad could be a good idea? Ifa
is an object with fields that you want to be able to read and update that sounds a bit like what you might want to useState
for. This can be combined with maybe something from the loop section of Control.Monad.Extra to make the intention of the code a bit clearer.If performance is critical you might be better of using a different language anyway (Haskell performance is okay but not amazing) but otherwise I don't think that this is really gonna slow down your code unacceptably much.
Lol. Yep, I'm a lame Haskeller.
This is a pattern that has repeated on different things, and the main reason I haven't done much Haskell in the past couple years. Maybe
State
is what I need, I'll have to look into it.See, I come from a maths background, and I have a bit of perfectionism going even if it's not a big deal. Maybe the processor can do a stupid thing and get away with it, but why should it?
What's that? Valuable programmer time you say? Pffft. I'll be over here designing a chess predicament with a multiply-infinite but well-defined solution to reach check (Yes, I've seen it done).