2025/04/06

Newest at the top

2025-04-07 00:39:07 +0200jacopovalanzano(~jacopoval@cpc151911-cove17-2-0-cust105.3-1.cable.virginm.net) (Quit: Client closed)
2025-04-07 00:39:01 +0200 <|cos|> koala_man: understandable! i wasn't really expecting it to be possible. the wine-idea is a creative approach!
2025-04-07 00:29:51 +0200merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) merijn
2025-04-07 00:19:15 +0200merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) (Ping timeout: 268 seconds)
2025-04-07 00:18:20 +0200Guest90(~Guest90@76.78.179.109) (Quit: Client closed)
2025-04-07 00:16:30 +0200target_i(~target_i@user/target-i/x-6023099) (Quit: leaving)
2025-04-07 00:13:56 +0200merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) merijn
2025-04-07 00:11:02 +0200 <hellwolf> here you go: https://github.com/hellwolf/haskell-examples/blob/master/2025-04-07-nfa-unboxed-linearity/nfa-perf… will share to discourse tomorrow with a few more details. feedback welcome.
2025-04-07 00:07:24 +0200ljdarj1ljdarj
2025-04-07 00:07:24 +0200ljdarj(~Thunderbi@user/ljdarj) (Ping timeout: 260 seconds)
2025-04-07 00:04:05 +0200ljdarj1(~Thunderbi@user/ljdarj) ljdarj
2025-04-07 00:03:12 +0200merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) (Ping timeout: 252 seconds)
2025-04-07 00:00:46 +0200gmg(~user@user/gehmehgeh) gehmehgeh
2025-04-07 00:00:04 +0200gmg(~user@user/gehmehgeh) (Remote host closed the connection)
2025-04-06 23:59:04 +0200 <yahb2> *** Exception: hmm ; ; HasCallStack backtrace: ; error, called at <interactive>:53:1 in interactive:Ghci12
2025-04-06 23:59:04 +0200 <EvanR> % error "hmm" >>= error "haw" :: IO Char
2025-04-06 23:58:55 +0200 <lambdabot> <IO ()>
2025-04-06 23:58:53 +0200 <monochrom> > putStrLn "<IO ()>"
2025-04-06 23:58:44 +0200 <monochrom> You will need yahb2 for that.
2025-04-06 23:58:37 +0200 <EvanR> lol
2025-04-06 23:58:30 +0200 <lambdabot> <IO Char>
2025-04-06 23:58:29 +0200 <EvanR> > error "hmm" >>= error "haw" :: IO Char
2025-04-06 23:58:17 +0200 <lambdabot> Identity *Exception: haw
2025-04-06 23:58:16 +0200 <EvanR> > error "hmm" >>= error "haw" :: Identity Char
2025-04-06 23:58:09 +0200merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) merijn
2025-04-06 23:56:47 +0200 <c_wraith> (the big difference here is that pattern-matching a data constructor causes evaluation, but matching a newtype constructor is a no-op)
2025-04-06 23:56:45 +0200 <dolio> I'm not certain that if you have multiple binds that the compiler can see, it isn't allowed to reorder them and stuff.
2025-04-06 23:56:44 +0200 <koala_man> |cos|: it's hard enough to try to stay compatible with different GHC versions, let alone anything else. if you have Wine then you could try running the windows binary
2025-04-06 23:56:13 +0200 <c_wraith> But it had better document how it's implemented.
2025-04-06 23:55:57 +0200 <c_wraith> It depends on how >>= is implemented. If it pattern matches its left argument, it does guarantee sequential evaluation to at least that constructor.
2025-04-06 23:55:26 +0200 <dolio> I think.
2025-04-06 23:55:04 +0200 <monochrom> Also, I used to have much fun with left recursion with Control.Monad.State.Lazy.
2025-04-06 23:54:08 +0200 <dolio> Data Identity doesn't really sequence things, either. At least, you aren't specified to be able to rely on it.
2025-04-06 23:53:58 +0200forell(~forell@user/forell) (Ping timeout: 268 seconds)
2025-04-06 23:53:50 +0200 <monochrom> OK right right.
2025-04-06 23:53:33 +0200 <c_wraith> Eh. It adds the opportunity for a data dependency
2025-04-06 23:53:13 +0200 <monochrom> (But Tardis would be an example where data dependency does not imply control flow sequentiency.)
2025-04-06 23:52:55 +0200 <EvanR> does it?
2025-04-06 23:52:34 +0200 <monochrom> OK, what you want to state instead is that monads necessarily adds data dependency.
2025-04-06 23:52:29 +0200 <EvanR> probably a bug in "what is sequentialize even"
2025-04-06 23:51:26 +0200 <c_wraith> What's funny is that if you take Identity and change it from newtype to data, leaving all the function definitions the same... it suddenly starts strongly ordering in >>=
2025-04-06 23:50:50 +0200 <monochrom> But one is really better off talking about one particular monad rather than general statements.
2025-04-06 23:50:15 +0200 <EvanR> e.g. Par is a monad
2025-04-06 23:50:13 +0200 <monochrom> What you want to state instead is that there is no guarantee that an arbitrary monad doesn't sequentialize things.
2025-04-06 23:49:27 +0200 <monochrom> The Identity Monad doesn't sequentialize things.
2025-04-06 23:49:06 +0200 <EvanR> no?
2025-04-06 23:48:54 +0200 <hellwolf> monad necessarily sequentialize things.
2025-04-06 23:48:17 +0200 <EvanR> linear base has several linear monads
2025-04-06 23:47:36 +0200kathryn1024_(~kathryn10@user/kathryn1024) (Ping timeout: 264 seconds)
2025-04-06 23:47:34 +0200merijn(~merijn@host-vr.cgnat-g.v4.dfn.nl) (Ping timeout: 272 seconds)