2025/01/16

2025-01-16 00:00:48 +0100 <haskellbridge> <magic_rb> if have a record such as "Foo { bar :: Text }" then I generate a lens called "bar", i cannot construct the record with "Foo { bar = "foobar" }". Is there any way around this? it complains about a ambiguous reference, though i dont see how he lens is a valid candidate on the LHS of "bar = "foobar"" anyway
2025-01-16 00:02:01 +0100mange(~user@user/mange) mange
2025-01-16 00:07:18 +0100__monty__(~toonn@user/toonn) (Quit: leaving)
2025-01-16 00:08:27 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn
2025-01-16 00:09:06 +0100Sgeo(~Sgeo@user/sgeo) Sgeo
2025-01-16 00:10:20 +0100sord937_(~sord937@gateway/tor-sasl/sord937) (Quit: sord937_)
2025-01-16 00:12:54 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) (Ping timeout: 252 seconds)
2025-01-16 00:16:37 +0100 <haskellbridge> <sm> Guest71: I probably wouldn't use a Hackage category or tag for this, I'd rely on a common package name prefix instead
2025-01-16 00:17:25 +0100 <haskellbridge> <sm> if you are able to publish as one package, it will simplify maintenance hugely
2025-01-16 00:17:48 +0100 <haskellbridge> <sm> maintenance and further packaging
2025-01-16 00:19:50 +0100notzmv(~umar@user/notzmv) notzmv
2025-01-16 00:20:30 +0100 <haskellbridge> <magic_rb> got it, somehow "DuplicateRecordFields" did it
2025-01-16 00:23:00 +0100stiell(~stiell@gateway/tor-sasl/stiell) (Ping timeout: 264 seconds)
2025-01-16 00:23:50 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn
2025-01-16 00:25:17 +0100stiell(~stiell@gateway/tor-sasl/stiell) stiell
2025-01-16 00:28:32 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) (Ping timeout: 272 seconds)
2025-01-16 00:29:48 +0100sawilagar(~sawilagar@user/sawilagar) (Ping timeout: 272 seconds)
2025-01-16 00:31:11 +0100Midjak(~MarciZ@82.66.147.146) (Quit: This computer has gone to sleep)
2025-01-16 00:32:16 +0100 <Guest71> sm: Thanks for your input. I was planning to use a prefix already, but I was wondering if there were additional conventions around grouping packages.
2025-01-16 00:32:16 +0100 <Guest71> On the topic of monopacking: I figured users would prefer to be able to pick micropackages as to avoid pulling in dependencies for pieces of the project they were not planning to use (reduce binary size and total logic surface). Am I wrong about this?
2025-01-16 00:33:39 +0100saulosilva(~saulosilv@181.216.220.107) (Quit: Client closed)
2025-01-16 00:39:13 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn
2025-01-16 00:39:47 +0100ljdarj1(~Thunderbi@user/ljdarj) ljdarj
2025-01-16 00:41:00 +0100califax(~califax@user/califx) (Ping timeout: 264 seconds)
2025-01-16 00:41:43 +0100califax(~califax@user/califx) califx
2025-01-16 00:42:03 +0100ljdarj(~Thunderbi@user/ljdarj) (Ping timeout: 245 seconds)
2025-01-16 00:42:03 +0100ljdarj1ljdarj
2025-01-16 00:43:39 +0100Guest69(~Guest69@2601:642:4103:1b0:a477:319d:e581:377a)
2025-01-16 00:43:40 +0100 <haskellbridge> <sm> you're not wrong, sometimes it is worth providing separate packages for that reason. But there's a maintenance and packaging cost to be carried for everymore, fewer larger packages will be less work
2025-01-16 00:44:21 +0100 <haskellbridge> <sm> how many packages are you contemplating ?
2025-01-16 00:46:00 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) (Ping timeout: 252 seconds)
2025-01-16 00:46:07 +0100mrmr155334346318(~mrmr@user/mrmr) mrmr
2025-01-16 00:46:20 +0100 <jackdk> Guest71: and also, how large are these packages (and their combination)?
2025-01-16 00:46:20 +0100 <haskellbridge> <sm> also sometimes even users prefer one or a few big packages, even if it's not optimal in bandwidth/disk space, it simplifies their life
2025-01-16 00:48:35 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn
2025-01-16 00:51:08 +0100 <Guest71> sm: Around 7 at the moment, but could potentially grow (basically there is a collection of implementations for a large interface, each implementation is its own repo, eventually more could be added for more use-cases). I am not too concerned about maintenance burden because the plan is to build a CI/CD pipeline to take care of that. Ideally I'd do
2025-01-16 00:51:08 +0100 <Guest71> that once, tweak slightly for each repo and then never think about it again. Should I be worried about something?
2025-01-16 00:51:09 +0100 <Guest71> jackdk: ~10 kloc a piece. For 7 repos that would be ~70 kloc.
2025-01-16 00:51:38 +0100 <geekosaur> you might look at amazonka for an example of how to do it?
2025-01-16 00:52:28 +0100 <jackdk> Amazonka IMHO is a special case because so much of it is autogenerated. But even there we eventually hope to trial multiple cabal sublibraries since we have to update the whole universe in lockstep anyway
2025-01-16 00:54:03 +0100 <jackdk> I'm not sure I'd call a 10kLoC package a "micropackage". That's no `left-pad` or `is-number`, and the PVP implications for a monopackage are not ideal: any backwards-incompatible change in one will bump PVP major version and make anyone not depending on the changed package go back and check for other breakage.
2025-01-16 00:54:09 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) (Ping timeout: 265 seconds)
2025-01-16 00:55:22 +0100 <jackdk> That said, now that I've read Guest71's question properly, breaking up an interface to a large API is probably a reasonable case for having at least multiple distinct sublibraries if not distinct packages (depend on how much lockstep updating you need to do if something changes)
2025-01-16 00:57:23 +0100lol_(~lol@2603:3016:1e01:b9c0:49df:554e:a17b:a07c)
2025-01-16 00:58:28 +0100 <jackdk> Is there any reason a monorepo with a cabal.project won't work for you here? That would save you building a lot of CI machinery, which is time you can spend writing more Haskell
2025-01-16 00:59:28 +0100 <jackdk> Amazonka is 3.8×10⁶ LoC, the vast majority of which is autogenerated, and it works fine enough
2025-01-16 01:00:51 +0100jcarpenter2(~lol@2603:3016:1e01:b9c0:794b:ce9f:2a3d:41ae) (Ping timeout: 252 seconds)
2025-01-16 01:02:39 +0100 <Guest71> jackdk: monopackage would work. I'm just thinking that from a UX point of view users in general do not want to pull stuff they will not use: larger binaries, larger logic surface means potentially more room to misuse/bugs, potentially worse test coverage, and as you said, now your API is less stable (more moving parts),
2025-01-16 01:03:16 +0100ljdarj1(~Thunderbi@user/ljdarj) ljdarj
2025-01-16 01:03:25 +0100 <haskellbridge> <sm> Guest71: it may be a good move, but you will have to think about it from time to time, even with automation, if you care about packaging (one or more of your packages will break with X ghc/dep version / on Y platform, disrupting your/packagers' scripts... etc.)
2025-01-16 01:03:37 +0100 <jackdk> Guest71: I mean monorepo, not monopackage. Cabal (and Stack too but I don't know the details) let you maintain several cabal packages in a single project repository, which you can then individually submit to Hackage.
2025-01-16 01:03:49 +0100ljdarj(~Thunderbi@user/ljdarj) (Ping timeout: 265 seconds)
2025-01-16 01:03:50 +0100ljdarj1ljdarj
2025-01-16 01:04:42 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn
2025-01-16 01:05:24 +0100lbseale(~quassel@user/ep1ctetus) ep1ctetus
2025-01-16 01:05:28 +0100 <jackdk> But I would also look at sublibraries which _should_ be usable everywhere now? Amazonka doesn't use them (yet?) because it predates them being widely available. Then you have a larger initial download but everything's in one place. Users still wouldn't compile things they don't need.
2025-01-16 01:06:09 +0100acidjnk_new(~acidjnk@p200300d6e7283f02edd754543fe6660f.dip0.t-ipconnect.de) (Ping timeout: 248 seconds)
2025-01-16 01:07:02 +0100 <Guest71> sm: I suppose that is always a possibility. But assuming I fix that for one package, then I would just apply the diff to the rest and be done, no?
2025-01-16 01:08:56 +0100 <Guest71> jackdk: It could work as a monorepo too. In fact, it used to be a monorepo and was later broken up (even the namespacing was mostly kept). Do you believe a monorepo with micropackaging would be better?
2025-01-16 01:09:38 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) (Ping timeout: 265 seconds)
2025-01-16 01:11:18 +0100 <jackdk> I consolidated work's split repositories into a monorepo, which has since grown to ~150kLoC. It was a large improvement because maintenance often topologically sorting the repositories in your head and working from the leaves up, and if something broke you often had to go back to the leaves and start again.
2025-01-16 01:11:32 +0100 <jackdk> The monorepo has been a massive QoL improvement. But the depgraph is relatively deep; if your project's depgraph is wide and shallow you might not hit this problem. Why did you split it up?
2025-01-16 01:12:49 +0100 <jackdk> Also, perhaps the term "split packaging" is more accurate than "micropackaging"? The latter makes me think of `left-pad` and single-function libraries.
2025-01-16 01:15:15 +0100 <jackdk> The way I see it, you have several options: 1a. monorepo, monopackage; 1b. monorepo, single package with sublibraries; 1c. monorepo, split packages; 2a. multi-repo, automated consolidation to single package; 2b. multi-repo, automated consolidation to package-with-sublibraries; 3. multi-repo, individual packages
2025-01-16 01:18:22 +0100 <jackdk> My gut says to avoid 1a because of the large compilation load it'll ask of your users. 1b and 1c seem reasonable, and since you're looking at updating bindings to a single broad interface I could imagine the versioning updating in lockstep. 2a and 2b look to me like they introduce a lot of devops complexity for benefit that I cannot see. 3 could cause a lot of dependency troubles if you have a deep depgraph.
2025-01-16 01:19:41 +0100Tuplanolla(~Tuplanoll@91-159-69-59.elisa-laajakaista.fi) (Quit: Leaving.)
2025-01-16 01:20:04 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn
2025-01-16 01:20:05 +0100 <Guest71> jackdk: Regarding the reason for the split, It was relatively easy to do (each component was contained in a submodule anyway) and figured there was no downside to doing it. On the upside, it enforces API boundaries, keeps your git history relevant (reverting or rebasing across submodules is no fun), and just plain keeps your workstation resource
2025-01-16 01:20:10 +0100Guest69(~Guest69@2601:642:4103:1b0:a477:319d:e581:377a) (Ping timeout: 240 seconds)
2025-01-16 01:21:48 +0100 <jackdk> I don't understand why you brought up git submodules. I agree that they are no fun - I'd have used wholly independent repositories or a single repository. A single cabal project will enforce package boundaries
2025-01-16 01:22:06 +0100 <jackdk> (between the package it contains)
2025-01-16 01:24:46 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) (Ping timeout: 252 seconds)
2025-01-16 01:26:53 +0100 <haskellbridge> <sm> Guest71: I'm just saying that all else being equal, many packages costs more to understand/maintain/package than one package. But all else isn't equal, it'll be an engineering judgement call
2025-01-16 01:28:33 +0100 <haskellbridge> <sm> long term maintainer and packager capacity, number and type of users are things to consider
2025-01-16 01:28:53 +0100 <Guest71> jackdk: Regarding the reason for the split, It was relatively easy to do (each component was contained in a submodule anyway) and figured there was no downside to doing it. On the upside, it enforces API boundaries, keeps your git history relevant (reverting or rebasing across submodules is no fun), and just plain keeps your workstation resource
2025-01-16 01:28:54 +0100 <Guest71> usage lower. I guess also mapping packages to repos 1-to-1 seemed better design all else being equal, but maybe I am wrong about that one. That's why I wanted input from the community.
2025-01-16 01:29:28 +0100 <haskellbridge> <sm> ot
2025-01-16 01:29:41 +0100 <Guest71> Oops, sorry about that. My message got replaced with a copy of the old thing.
2025-01-16 01:29:58 +0100 <haskellbridge> <sm> it's worth thinking about, because you can't erase things uploaded to hackage, or easily rearrange VC history
2025-01-16 01:30:02 +0100 <jackdk> I just had the strangest case of deja vu
2025-01-16 01:30:34 +0100 <haskellbridge> <magic_rb> Ive heard that overly polymorphic code doesnt specialize well, but then id ask why? Because couldnt GHC track what different instantiations of each toplevel binding occur and then based on some metric (plain count, expected machine code size) specialize automatically? I assume something like this happens already, but question is why not well enough where "overly polymorphic" ceases to be a problem
2025-01-16 01:32:44 +0100 <haskellbridge> <sm> will docs/changelogs be easy to segment by package ? Will you always release all packages in lockstep, or will you allow say a bugfix release to an individual package, complicating release scripts ? etc.
2025-01-16 01:33:25 +0100 <haskellbridge> <sm> issue tracker per package ?
2025-01-16 01:33:31 +0100 <Guest71> I was going to say that I wasn't meaning to say git submodules, but Haskell submodules (let's call them subprojects). What I was trying to say is that keeping a monorepo means that a subproject's history is merged together with everything else, which means more work around handing history.
2025-01-16 01:33:32 +0100 <Guest71> As for the boundary enforcement, it is true that you may enforce it with cabal. I suppose in my mind that is a sort of "softer" enforcement than splitting repos (boundary enforcement is regulated by a file inside the project repo), so I just reached for the most generic solution. Maybe this was a bad call?
2025-01-16 01:34:24 +0100 <haskellbridge> <sm> I think we don't know enough to have (more of :) an opinion
2025-01-16 01:35:29 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn
2025-01-16 01:36:18 +0100JuanDaugherty(~juan@user/JuanDaugherty) JuanDaugherty
2025-01-16 01:36:40 +0100 <Guest71> sm: issue tracker per package, yes. Docs are basically pure Haddock, so they are split already. I would not release in lockstep.
2025-01-16 01:37:43 +0100 <jackdk> That Haskell calls a source file a "module" means I find it confusing to call a unit of project organisation a "submodule", especially when that word had meaning to `git`. For clarity: a cabal "package" has multiple "components" (library, named sublibrary, executable, test suite, etc). One or more "packages" on the filesystem can be collected into a "project", where `cabal.project` lets you apply settings across them.
2025-01-16 01:38:01 +0100 <haskellbridge> <sm> will people often want to install all the packages together ? It sounds like not
2025-01-16 01:38:56 +0100 <Guest71> sm: I'm expecting not, except for users that happen to have different use-cases that could be better served by different implementations
2025-01-16 01:39:10 +0100 <JuanDaugherty> 'source module" is an ancient idiom for a single file of code text
2025-01-16 01:39:37 +0100 <JuanDaugherty> as opposed to "object module"
2025-01-16 01:39:56 +0100 <haskellbridge> <sm> +1 to jackdk. "package" is the right term for units of hackage/cabal/stack-stuff
2025-01-16 01:40:03 +0100 <geekosaur> (for which we have IBM to blame, IIRC)
2025-01-16 01:40:04 +0100sprotte24(~sprotte24@p200300d16f35c200f4f310a9fb58ced0.dip0.t-ipconnect.de) (Read error: Connection reset by peer)
2025-01-16 01:40:05 +0100 <Guest71> Okay, point taken. What's the best way to call everything under a namespace?
2025-01-16 01:40:16 +0100 <JuanDaugherty> yes them
2025-01-16 01:40:19 +0100 <geekosaur> which kind of namespace?
2025-01-16 01:40:33 +0100 <geekosaur> if you mean module namespaces, they're pretty fake
2025-01-16 01:40:36 +0100 <Guest71> As in I have lib/Foo/Bar/Baz.hs
2025-01-16 01:40:40 +0100 <haskellbridge> <sm> a project can consist of one or more repos which may store one or more packages
2025-01-16 01:40:44 +0100 <Guest71> What do I call everythin under Foo/Bar?
2025-01-16 01:40:44 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) (Ping timeout: 272 seconds)
2025-01-16 01:40:51 +0100 <Guest71> The modules called Foo.Bar.*
2025-01-16 01:40:57 +0100 <geekosaur> modules
2025-01-16 01:40:58 +0100 <jackdk> Without knowing what the mysterious API is, it sounds like the bindings are more loosely coupled than Amazonka's. This makes me lean toward either option 1c (monorepo with split packages) or 3 (split repos with individual release infrastructure)
2025-01-16 01:41:15 +0100 <geekosaur> there is no real concept of related-ness; a different package could also use the Foo.Bar "namespace"
2025-01-16 01:41:41 +0100 <JuanDaugherty> cause in that time computers were called ibm machines so their usages became industry norms, even tho there was actually much greater arch diversity
2025-01-16 01:41:57 +0100 <Guest71> I can tell more about the project, it's not a secret. I just don't want to overwhelm you with noise.
2025-01-16 01:42:59 +0100 <Guest71> The project originally had a form of Foo.Iface, Foo.Bar.Baz1, Foo.Bar.Baz2, Foo.Bar.Baz3... all the BazN modules implement the Foo.Iface
2025-01-16 01:43:21 +0100 <JuanDaugherty> "module" is more of a construct and often enough contentious, eg. in prolog
2025-01-16 01:43:37 +0100 <jackdk> I think knowing the specific interface would be extremely helpful, if you can provide it.
2025-01-16 01:43:45 +0100 <jackdk> At least its name, I mean.
2025-01-16 01:44:49 +0100califax(~califax@user/califx) (Remote host closed the connection)
2025-01-16 01:45:08 +0100califax(~califax@user/califx) califx
2025-01-16 01:45:51 +0100 <Guest71> jackdk: it's called Nera
2025-01-16 01:46:13 +0100 <Guest71> Though I imagine you were hoping for something descriptive
2025-01-16 01:47:13 +0100xff0x(~xff0x@2405:6580:b080:900:8310:6e2:3d63:5127) (Ping timeout: 248 seconds)
2025-01-16 01:47:38 +0100 <jackdk> Ideally a link to a high-level API page. So far I have found a page on cloud-based aged care software and a PDF report from a consultancy about Smart Meters for the Australian Energy Market Commission. Please, help us help you.
2025-01-16 01:47:44 +0100 <JuanDaugherty> can a namespace just be a namespace? names r powerful, their rectification is a whole deal
2025-01-16 01:48:15 +0100 <Guest71> Oh, sorry, it isn't public as of right now.
2025-01-16 01:48:40 +0100 <Guest71> I'm currently in the process of trying to publish it, hence this conversation :)
2025-01-16 01:49:06 +0100 <Guest71> It basically combines a bunch of numeric interfaces and add some other stuff on top
2025-01-16 01:49:11 +0100 <Guest71> It's a numeric library
2025-01-16 01:50:04 +0100 <Guest71> JuanDaugherty: sorry, I'm not sure what you meant by that (re: namespaces being just namespaces)
2025-01-16 01:50:09 +0100JuanDaughertyColinRobinson
2025-01-16 01:50:52 +0100merijn(~merijn@128-137-045-062.dynamic.caiway.nl) merijn