Not in general.
29.09.2025 07:21 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0@borar.bsky.social
Not in general.
29.09.2025 07:21 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0What I meant is the term "railroad" is specifically conceived in the F# "world" so it's logical that one does not find it elsewhere. CEs are a concrete language feature which, although similar to do notation, is unique enough. So similarly normal to not see it elsewhere :)
28.08.2025 11:24 โ ๐ 2 ๐ 0 ๐ฌ 1 ๐ 0The first two are F#-specific.
25.08.2025 06:30 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 011 years for me...
05.06.2025 10:58 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0What was the problem or question to solve?
08.05.2025 09:08 โ ๐ 1 ๐ 0 ๐ฌ 1 ๐ 0This is another formulation of my point. Unfortunately the "human factor" seems to be somehow a notion in the software industry. But it is nonsensical in other engineering disciplines. Rightly so, because it comes down to individualistic anti-intellectual stance and that learning is special.
03.04.2025 11:40 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 0The "needs" are indeed relevant when we deal with different categories of applications: F# is not better for systems or embedded or game programming, Rust, C, etc. are better. But F# and C# are the same category so the "needs" are the same.
02.04.2025 13:35 โ ๐ 0 ๐ 0 ๐ฌ 2 ๐ 0While I understand the good intentions behind such reocurring statements, I am less careful and "politically" balanced: #fsharp is absolutely inherently better. The "needs" are irrelevant, objective properties are what matters in engineering. Just like precise power tools vs manual mediaval tools.
02.04.2025 13:31 โ ๐ 6 ๐ 0 ๐ฌ 2 ๐ 0I am guessing you mean something like "if/when the last F# programmer leaves"? This is very unlikely, either there are more remaining or others who can pick it up. People can learn things :)
13.03.2025 18:43 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 0The right answer is indeed "you don't need to hire F# programmers".
13.03.2025 18:14 โ ๐ 1 ๐ 0 ๐ฌ 1 ๐ 0Even more so, given that the seminal paper on F# computation expressions just uses the monad and monoid terminology extensively, as it should.
12.03.2025 14:48 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0Seq does have bind though, it's only called differently.
12.03.2025 11:27 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0Functional programming and its idioms are the most fitting and sensible interpretation/realization of #eventsourcing. Fold multiple composable values of types provided by the layered model, alongside the use-case specific version, apply model logic, store a new record. "Aggregates" are a mistake.
10.03.2025 14:55 โ ๐ 2 ๐ 0 ๐ฌ 0 ๐ 0The best language for the Web!
10.03.2025 14:44 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0Why would people use other programming languages for frontend dev when #PureScript is just right there?
#FunctionalProgramming
I think I understood the popularity of "modern" as a term. It embodies the implicit and unconcious understanding that most of the (visible online) software industry is a web of ad-hoc, anti-fundamental knowledge, hype-driven, half-assed ideas which break easily. Then its on to the next "modern".
10.03.2025 09:35 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0And then there is PureScript as well.
28.02.2025 06:57 โ ๐ 4 ๐ 0 ๐ฌ 0 ๐ 0Usually the "mini applications" are easy to recognize and define unambiguosly. Evolution of long-lived business applications follows this as well: a new (business) capability needs to be added, which clearly belongs to the application, but is stand-alone within the problem domain.
27.02.2025 21:55 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 0Persistence is also, in general, shared. Some DB tables can be used by multiple components, some are specific to one. With #eventsourcing the journal and the record type is shared.
27.02.2025 21:52 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0Every vertical component has its own data access interfaces (remember, Onion), URL handlers, data access implementation, tests, etc. Vert. components can also share types and functions from "common modules" which are at the "base" of the vert. components. For example the common User type. ๐ฝ
27.02.2025 21:50 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 0All use-cases for stock management of scheduling are two other vertical components. Multiple vertical components can have their own models of the same domain notion, tailored at their purpose. A User type appears everywhere, but is more extensive/different in the user management vert. component. ๐ฝ
27.02.2025 21:48 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 0A vertical slice, which I usually call a vertical component, is a cake piece going through all layers of the Onion. It is a mini application on its own, in a way, focusing on a set of related use-cases. Not too fine-grained, for example all use-cases of user management is one vert. component. ๐ฝ
27.02.2025 21:46 โ ๐ 0 ๐ 0 ๐ฌ 2 ๐ 0My 5c about this, as always somewhat heretical. "Bounded context" is vague and not really interesting/useful. Vertical slice architecture is not an architecture, but a principle *within* an architecture. In particular, in the Onion architecture (my default). #DDD ๐ฝ
27.02.2025 21:43 โ ๐ 1 ๐ 0 ๐ฌ 1 ๐ 0Only if you are making a fat client and the back-end is merely a thin layer between it and the DB and other infra.
21.02.2025 13:51 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0Maybe thou pure just followeth m, returneth to sanity of
m.
I see. What is the difference with a function returning a Lazy and possibly performing side-effects?
17.02.2025 14:56 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0Once evaluated, Lazy always returns the same value without re-evaluation. Does this "caching" also happen here?
15.02.2025 18:42 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 0Having said that, PureScript is like you are suggesting: F# 'match <exp> with' in PureScript is 'case <exp> of' and 'function' is simply 'case _ of'.
15.02.2025 18:39 โ ๐ 0 ๐ 0 ๐ฌ 0 ๐ 0A function in its nost basic representation, as learned at school, is a table with two columns. From this point of view, the 'function' keyword and what follows it makes total sense.
15.02.2025 18:37 โ ๐ 0 ๐ 0 ๐ฌ 1 ๐ 0Just to be sure, are you compiling in the release mode with tail call optimization turned on?
Secondly, did you try making the nested function a top-level one?