Elm at Rakuten
folex 2021-08-18 15:37:00 +0000 UTC [ - ]
I mean, a lot of libraries aren't updated to the last lang version, debugging JS-Elm interactions been a real challenge for years, yadda yadda. Overall I'd say Elm ecosystem doesn't receive enough attention to survive.
I'm not complaining, I'm just sad about that and kinda surprised I didn't found a mention of that in the OP article.
jaeming 2021-08-18 15:59:32 +0000 UTC [ - ]
See posts like these for more details and comments:
https://news.ycombinator.com/item?id=16510267
https://news.ycombinator.com/item?id=22821447
There are also several great alternatives now. F# with Fable and Elmish for example: https://zaid-ajaj.github.io/the-elmish-book/#/
And Bucklescript TEA with Ocaml or Reason: https://github.com/OvermindDL1/bucklescript-tea
Some others have also gone on to develop new languages taking inspiration from Elm: https://www.mint-lang.com/
rtfeldman 2021-08-18 16:10:12 +0000 UTC [ - ]
I spent a bunch of time doing that in the past, and eventually stopped because I felt like Sisyphus. The same people would crop up on the next thread repeating the same things anyway. Of course if the claims go unchallenged, it leads to the perception that they're accurate...but that doesn't make engaging with them any more enjoyable a way to spend one's free time.
If you want to check the health of the Elm community, visit Elm Slack and ask in the #beginners channel how people feel about it. It takes about the same amount of time as posting a HN comment, but it gives a very different perspective than the one you'd get if your main source of Elm information was Hacker News comments! :)
Latty 2021-08-19 16:51:24 +0000 UTC [ - ]
I've tried to push for fixing the use of CSS Custom Properties in Elm a couple of times (https://discourse.elm-lang.org/t/css-custom-properties/5554) and it really felt like talking to a wall.
The community absolutely suffers whenever anyone comes across one of these issues where there just isn't a solution, and more than that, no communication at all. It implies the project is dead.
I accept that Elm is functionally just stalled and won't see any changes until some arbitrary point in the future, I can live with that. I don't think the project communicates it's state and direction well though, and that leads people to disappointment and the posts you see.
superdisk 2021-08-18 16:45:31 +0000 UTC [ - ]
On top of this, the community is run like a dictatorship. Dissent is silenced and banned, and faux positivity is spread far and wide. I got sick of it and was banned from the Elm subreddit after I expressed my frustration. That's pretty much when I gave up on the language, years ago, on version 0.18 (fwiw, they're on version 0.19 now, that's how slow updates are)
rtfeldman 2021-08-18 17:02:41 +0000 UTC [ - ]
I don't use Reddit anymore, but if memory serves there have been about 5 people total banned from the aforementioned Elm subreddit, which is fewer than 1 ban per year it's existed.
I invite anyone to evalute the accuracy of "Dissent is silenced and banned" with that data point in mind, and to evaluate the accuracy of the other above claims accordingly.
zoul 2021-08-18 17:45:03 +0000 UTC [ - ]
rtfeldman 2021-08-18 17:57:43 +0000 UTC [ - ]
My personal experience has been different, but I upvoted this because I really appreciated that you shared your own experience without overgeneralizing it.
cultofmetatron 2021-08-18 17:25:33 +0000 UTC [ - ]
I've not heard of such misinformation being spread about other languages. Id love to hear your side on why Elm itself seems to attract such ire if its inaccurate.
rtfeldman 2021-08-18 17:45:09 +0000 UTC [ - ]
I think there's more than one factor, but the biggest one comes down to setting expectations, especially in the early days.
Elm does a lot of things differently than other languages, and while I think that overall those differences have been instrumental to its success, especially early on it sometimes wasn't clearly enough communicated when "this is temporarily different because it's a WIP; you can expect it to be more like what you're used to in the future" versus "this is different by design, so expect it to stay different or even to become more different."
Examples of this include typeclasses (a lot of people coming to Elm from a Haskell background assumed Elm would add them as a matter of course), JS interop (by design, it's not a traditional FFI, although there was an unintended backdoor that kind of worked like one; when that backdoor was finally removed, after much communication that in retrospect should have happened at the outset, some of those who had been relying on it were understandably upset), how the project is run (more like Clojure than like JavaScript), and what the release schedule looks like (batching large projects rather than more frequent smaller releases).
I think things are a lot clearer today, but for some it's unfortunately too late to make a difference.
gaereth 2021-08-18 20:03:29 +0000 UTC [ - ]
G4BB3R 2021-08-18 20:52:09 +0000 UTC [ - ]
hashbig 2021-08-18 22:41:57 +0000 UTC [ - ]
The Elm contributor circle is a clique that you literally have to be a strong contact with one of the contributors to get into it. It goes against everything open source stands for.
slgeorge 2021-08-19 07:53:15 +0000 UTC [ - ]
Sorry, that's not correct. It goes against your opinion of what open source should stands for, and many projects run in a way where everyone can contribute. But, it's not the only way.
The license determines how the code comes, that's the only rule. There's no rules about how a community must run. It's for the code creator (maintainer) to determine how or even IF they want a community of contributors. There's lots of ways of doing open source!
And saying it's not "open source' if you don't do X outside the license is just a No true Scotsman.
ghayes 2021-08-19 01:10:46 +0000 UTC [ - ]
gaereth 2021-08-19 08:45:53 +0000 UTC [ - ]
razze 2021-08-19 14:39:28 +0000 UTC [ - ]
jaeming 2021-08-18 18:58:19 +0000 UTC [ - ]
I'll add a reply to my comment to make it clear this is hearsay and doesn't necessarily reflect the truth.
jaeming 2021-08-18 19:05:19 +0000 UTC [ - ]
xupybd 2021-08-19 03:11:25 +0000 UTC [ - ]
What Evan is doing with Elm is awesome, he has a small closed set of features to make a language that is aimed at doing one thing. He has very tight control to make sure there is zero cruft in the language. It's an amazing project. The cost is that it's very hard for outsiders to have any input into the language. So the ecosystem will never take off.
brainbag 2021-08-18 16:49:21 +0000 UTC [ - ]
mechelephant 2021-08-18 15:55:49 +0000 UTC [ - ]
Debugging elm-JS interactions is not really a problem when using the standard interop methods of ports and webcomponents. It's just not something that comes up often.
Source: have been writing elm professionally for the last 2 and a half years.
aeturnum 2021-08-18 19:56:31 +0000 UTC [ - ]
So my own personal Elm projects have involved a lot of reading other code and often copying and modifying open source code, but it's hard to wholesale import components in the way that JavaScript and other languages do it. My experience with the language is that it is very easy to do what I want in it, but it seems more difficult to share that as an open source contribution in Elm than in similar languages.
agbell 2021-08-18 17:58:14 +0000 UTC [ - ]
His experience working at a teaching company made his book very well structured for new comers.
arcade79 2021-08-18 17:20:23 +0000 UTC [ - ]
(For younglings: elm was an email client. pine was also an email client. The latter was often thought to be short for 'pine is not elm').
fatnoah 2021-08-18 19:35:28 +0000 UTC [ - ]
wing-_-nuts 2021-08-18 17:40:58 +0000 UTC [ - ]
dmix 2021-08-18 16:43:20 +0000 UTC [ - ]
ES6 module imports really helped solve this problem and is a giant step forward in the JS ecosystem. Despite being relatively straight forward they were (and are) a big deal.
Any JS project before that was a giant dance of complex window namespacing, closure wrappers, and hoping the 3rd party library you’re using doesn’t expect some weird custom thing to ‘import’ it.
The next step obviously is fixing bundling and replacing Webpack and Babel (the closest thing to a widespread standard today in JS) with something less magicy and more native. And these are a big reason newbies/non JS devs freak out when they see a thousand packages in starter kits.
These two things (importing and bundling/preprocessing) were a big reason why there always seemed to be a never ending output of new build tools. Just having those two to be predictable is a godsend in any JS developers but IRL even the best internal practices was never consistent across libraries, teams, and projects.
I’ve always wondered how much frameworks like Elm and similar are motivated simply but attempting to establish best practices and standards in JS projects vs the abstraction/language innovations they provide (like pure FP and reactivity stuff). It’s at least 50% of the value proposition.
The big question is whether it will be for long enough to be worth the investment.
hashkb 2021-08-18 17:16:14 +0000 UTC [ - ]
ferdowsi 2021-08-18 19:10:45 +0000 UTC [ - ]
[1]https://news.ycombinator.com/item?id=22821447 [2] https://www.reddit.com/r/elm/comments/7zk0dy/is_evan_killing...
StefanWestfal 2021-08-18 22:13:15 +0000 UTC [ - ]
roebk 2021-08-18 19:33:45 +0000 UTC [ - ]
StefanWestfal 2021-08-18 17:47:21 +0000 UTC [ - ]
Elm-UI made working with styling much easier for me and was the main reason I gave Elm a try.
The Evan and the core team seem to have a clear vision of what they want and I can understand that but this is personal opinion. To make a system work well you have to be strict and including new features all the time might introduce complexity down the line. This might seem a bit closed in form the outside.
So far I am very happy with it.
dsiegel2275 2021-08-18 17:52:39 +0000 UTC [ - ]
mchusma 2021-08-19 13:59:58 +0000 UTC [ - ]
By that I means they use affiliate links to make money.
But most of their referred traffic comes from people checking out and saying "I use rakuten to get a discount at the places I already shop".
The stores then don't know how much business rakuten is really bringing them, so are scared to stop it.
Consumers keep checking rakuten to see if they get discounts on things they want, because why not?
Is this a good summary? Anyone have a more favorable impression of their work (from the store perspective)?
nopcode 2021-08-19 15:34:50 +0000 UTC [ - ]
They have a very different type of presence in different countries.
mouzogu 2021-08-18 15:40:23 +0000 UTC [ - ]
Probably, one of my biggest career mistakes was opting for a little known PHP cms instead of WP as I thought it would be easier for the stakeholders to work with the limited options.
Since then, I've always avoided going away from the mainstream toolset.
g_delgado14 2021-08-18 15:48:17 +0000 UTC [ - ]
Yes, however:
- Elm has a very small surface area (you can read through the guide [0] in a weekend)
- There are many folks who love functional programming && are willing to learn Elm
So, given those two facts, the lack of Elm developers compared to other "markets" is not a big issue.
For me, personally, the only risk with Elm is its incredibly opaque development. It's led by Elm's BDFL and a few other folks and it's almost as though they go out of their way to make Elm hard to adopt for outsiders.
For example, all you have to do is change elm's version to 1.0.0 to signal to outsiders that, yes .. Elm is and has been production ready for quite a while now (years?). Instead "insiders" will reason and rant about how 0.19.1 is fine.
----
blowski 2021-08-18 16:13:56 +0000 UTC [ - ]
That said, I know very little about Elm and would love to understand more about what it offers that's so exciting. I skim-read the article, will read in more detail later.
matsemann 2021-08-18 20:54:31 +0000 UTC [ - ]
MichaelGlass 2021-08-18 21:32:58 +0000 UTC [ - ]
In the end, we hire interesting, curious devs, and ask them to use tooling (elm) that has a pretty shallow learning curve.
I think bootstrapping a project in Elm without any experience on the team could be tough, but once you have some expertise, the seeds you plant in yield abundant fruit. At NoRedInk it's been a great success -- especially with regards to "finding other developers".
tmm84 2021-08-19 01:42:44 +0000 UTC [ - ]
tempest_ 2021-08-18 15:25:41 +0000 UTC [ - ]
It is a bit off putting.
It is nice to see a different perspective.
z5h 2021-08-18 16:28:46 +0000 UTC [ - ]
razze 2021-08-19 14:55:49 +0000 UTC [ - ]
Existenceblinks 2021-08-18 16:53:04 +0000 UTC [ - ]
Since Elm is immutable and lazy render, most of the time, compare underline object reference (referential equality check), the reference (memory location) almost always changes on every update cycle because it needs to update model, thus, a new reference as a result. And that makes Html.Lazy worthless. I had some kind of 1000 html tree nodes, and it rendered every branch every time. I probably did something not right, but I already tried solving that for a few days, no success.
If you have the Elm in Action book, that memory location pitfall is explained on the very last page about when memory location of a object changes.
dzonga 2021-08-19 00:49:43 +0000 UTC [ - ]
wolfadex 2021-08-19 11:45:36 +0000 UTC [ - ]
GiorgioG 2021-08-18 17:51:00 +0000 UTC [ - ]
razze 2021-08-19 15:00:35 +0000 UTC [ - ]
G4BB3R 2021-08-18 20:31:36 +0000 UTC [ - ]
GiorgioG 2021-08-18 21:01:45 +0000 UTC [ - ]
neals 2021-08-18 18:23:01 +0000 UTC [ - ]
deergomoo 2021-08-18 20:46:35 +0000 UTC [ - ]
A Japanese tech conglomerate.
> Why is it on all my Samsung TV's?
Because Samsung have no shame and will gladly ruin their own products for a quick buck.
b7bfcdeaab33 2021-08-19 01:51:54 +0000 UTC [ - ]
What do you lose in this trade off?
agumonkey 2021-08-18 17:24:40 +0000 UTC [ - ]
osener 2021-08-18 18:11:55 +0000 UTC [ - ]
agumonkey 2021-08-18 18:34:27 +0000 UTC [ - ]
I didn't even try to find about it last year, it seemed the only ui lib for purescript with a tiny docs website (beige / pale themed)
Really surprised not being able to find it again.. I'll reply again if I end up finding it
dodecaphonic 2021-08-18 21:52:03 +0000 UTC [ - ]
fulafel 2021-08-18 21:38:33 +0000 UTC [ - ]
wolfadex 2021-08-18 21:53:49 +0000 UTC [ - ]
Or if you want to do Elm full stack there's https://lamdera.com/ or https://package.elm-lang.org/packages/choonkeat/elm-fullstac....
whichdan 2021-08-19 00:58:10 +0000 UTC [ - ]
girishso 2021-08-19 02:17:27 +0000 UTC [ - ]
decafbad 2021-08-18 18:56:18 +0000 UTC [ - ]
mkose@casper:~/Desktop$ ./elm repl
---- Elm 0.19.1 -----------------------------------------
> Basics.modBy 0 3
Error: Cannot perform mod 0. Division by zero error.
earth_walker 2021-08-18 20:06:30 +0000 UTC [ - ]
https://math.stackexchange.com/questions/516251/why-is-n-mod...
decafbad 2021-08-18 21:14:08 +0000 UTC [ - ]
girishso 2021-08-19 02:31:40 +0000 UTC [ - ]
I will consider it sticking to it's promise of no runtime errors.
1-more 2021-08-19 01:01:20 +0000 UTC [ - ]
sergiotapia 2021-08-18 16:05:20 +0000 UTC [ - ]
jeofken 2021-08-18 16:08:48 +0000 UTC [ - ]
They don’t hinder anyone from forking and removing this limitation, allowing any package author to run native code on your machine.
macintux 2021-08-18 16:30:26 +0000 UTC [ - ]
That has arisen a few times here. Yes, they actually do actively discourage forking (to the point of threatening “excommunication” from the community).
rtfeldman 2021-08-18 18:19:55 +0000 UTC [ - ]
There have been a couple of forks with different names, and nobody's been "excommunicated" or whatever. The forks haven't gotten much traction, but they're probably still out there.
macintux 2021-08-18 18:34:36 +0000 UTC [ - ]
Added: This comment is also not terribly friendly.
https://github.com/gdotdesign/elm-github-install/issues/62#i...
rtfeldman 2021-08-18 18:56:16 +0000 UTC [ - ]
As it turned out, this is exactly what the OP in that thread did - he created https://www.mint-lang.com - which I think is a very positive development indeed!
macintux 2021-08-19 00:27:57 +0000 UTC [ - ]
G4BB3R 2021-08-18 18:25:12 +0000 UTC [ - ]
https://discourse.elm-lang.org/t/clients-expressing-doubt-ab...
macintux 2021-08-18 18:47:15 +0000 UTC [ - ]
macintux 2021-08-18 18:34:20 +0000 UTC [ - ]
Added: This comment is also not terribly friendly.
https://github.com/gdotdesign/elm-github-install/issues/62#i...
jeofken 2021-08-18 18:01:36 +0000 UTC [ - ]
macintux 2021-08-18 18:06:11 +0000 UTC [ - ]
I’d be fine forking it to pursue a personal project. I’d never do that for any critical business need.
jeofken 2021-08-19 10:32:44 +0000 UTC [ - ]
• When you want to update to a new version of Elm, do git rebase and reapply the patch.
• Now your source tree and history is identical to upstream, plus one commit
Most likely the code restricting installing binaries from only one source isn’t changing a lot, so patch conflicts should not be too much of a hinderance
vmchale 2021-08-18 17:35:39 +0000 UTC [ - ]
jeofken 2021-08-19 10:37:30 +0000 UTC [ - ]
aaronchall 2021-08-18 15:41:19 +0000 UTC [ - ]
I did get an Elm app upgraded from 0.18 to 0.19 without too much extra work, but I'm concerned a major version release may bring much more changes.
moistoreos 2021-08-18 16:19:36 +0000 UTC [ - ]
hitekker 2021-08-18 15:28:16 +0000 UTC [ - ]
pianoben 2021-08-18 15:43:37 +0000 UTC [ - ]
cfors 2021-08-18 15:44:27 +0000 UTC [ - ]
https://elmtown.simplecast.com/episodes/it-just-goes-on-and-...
Obviously Microsoft is a huge company so they use all of the languages, but I find it surprising given the amount of investment they've made into Typescript.
Zababa 2021-08-18 16:25:50 +0000 UTC [ - ]
PragmaticPulp 2021-08-18 15:08:59 +0000 UTC [ - ]
> Our JavaScript application had global variables everywhere, and debugging was a nightmare
Point #3 in their list of cons is especially important for anyone considering Elm:
> Because Elm is not a mainstream language, it is sometimes necessary to reinvent something that could otherwise have been acquired by adopting a different technology.
This is the biggest downfall of Elm projects that I’ve seen in the real world. Teams end up spending half of their time or more solving problems that could have been accomplished quickly with some off the shelf React libraries with numerous tutorials online.
This attracts a lot of developers who enjoy working on libraries and tooling, but it’s not ideal if you’re trying to run a lean team that ships products quickly.
Elm is fun, but I wouldn’t use it unless I could afford to hire a relatively huge team to absorb all of the additional complexity and detours that go into building an Elm app. There’s a constant promise of Elm being faster and easier to write for various reasons, but in practice it always seems to get bogged down in endless gotchas and framework shortcomings that need to be addressed before we can get down to getting real work done.
whateveracct 2021-08-18 18:37:42 +0000 UTC [ - ]
The freaking out about "oh no I gotta write a small library myself" is absurdly overblown here. Most of the time I see it, it's people flipping out at the very sight of there not being something available off-the-shelf. The actual cost is much lower than the panic implies.
In general, people see ANY time spent in an FP language to solve FP problems as "a waste of time" but they're blind to the wastes of time people treat as "real code" in mainstream languages.
But yeah if you're a software efficiency bean counter, maybe you won't like FP. Fair point.
My opinion is the long-term technical & cultural benefits and opportunities pay off. And as a developer, I am happy to not optimize my development velocity to the utmost if it means I don't have to waste my brainpower writing imperative code. My mind is in a much better state at the very least :)
vlunkr 2021-08-18 19:46:24 +0000 UTC [ - ]
This isn't a good representation of the argument. People don't want to write libraries because it's more valuable for everyone to spend time writing features using existing libraries, provided there are good libraries available. People aren't "freaking out", they just have deadlines, and you know, other things to do with their lives besides write code that has already been written.
mst 2021-08-18 21:10:47 +0000 UTC [ - ]
whateveracct 2021-08-18 21:19:04 +0000 UTC [ - ]
adamwk 2021-08-18 23:16:58 +0000 UTC [ - ]
whateveracct 2021-08-19 03:50:22 +0000 UTC [ - ]
If you choose an FP language like Haskell, you tend to value things beyond that. Stability, engineering culture, retention, big rate, the ability to extend things for cheap only because you did the hard part of using Haskell to begin with, etc
It's just throughput vs latency
kingaillas 2021-08-18 20:11:24 +0000 UTC [ - ]
I don't think it is.
At work, I'm adding some basic metrics/logging functionality to an internal library, to see how it's being used. The idea is to log a few parameters and the tech lead suggested using JSON format.
No problem right? Well my work environment is quirky and let's just say it is hard to use outside libraries for various reasons. It can happen there is just a lengthy IT process to go through... eventually most reasonable requests will be filled (copied/mirrored internally, or binaries imported). But there is a delay.
This is all besides the point other than to say: I either need to wait a few weeks, or write my own minimal JSON library.
How hard can that be? I mean, it's just JSON. Well earlier today I was checking reddit and saw an announcement that "JSON for Modern C++ was released" (https://www.reddit.com/r/cpp/comments/p69plb/json_for_modern...). Hey cool, I can see what the library looks like and maybe rip off some of their code while I'm waiting for a "please mirror this internally" request to finish.
This library is thousands of lines long... for JSON. I'm not disparaging the author or JSON, it looks like an awesome library with great diagnostics, I'm more trying to point out that even for the SIMPLE format of JSON, a serious library is 10K+ lines. That's a hell of a lot of extra work to put on a team when writing a JSON (or whatever) library probably isn't the actual work that needs to be done.
Elm likely has a JSON library ready to use, but having your seasoned team reinventing the wheel for so many other libraries isn't a good use of dev time. I can't think of simpler libraries to write than JSON and even that is 10K lines long. Other than the insanity of nodejs and leftpad and libraries like that. If the attitude for every single library needed is "we can write that from scratch" the team is never going to get anywhere.
whateveracct 2021-08-18 21:32:12 +0000 UTC [ - ]
You can define a JSON AST type very simply, and then converting that to wire bytes is also quite trivial. Also simple to test via golden testing (you could even use property testing + shell out to jq to validate the json)
https://github.com/nikita-volkov/jsonifier This one is nowhere near 10k lines - and it is heavily optimized and polished!
panzagl 2021-08-18 21:17:39 +0000 UTC [ - ]
PragmaticPulp 2021-08-18 21:24:14 +0000 UTC [ - ]
> My opinion is the long-term technical & cultural benefits and opportunities pay off.
How, though? These two points contradict each other. Is using FP going to pay off with technical benefits? Or is it just going to reduce your software development efficiency?
I enjoy writing FP code and using niche frameworks like Elm for hobby projects, but I specifically avoid them for production work because I'm familiar with them.
I always hear claims that using Elm and niche languages is going to pay off in vague benefits somewhere down the road, but in practice the payoff never really arrives. I think a lot of developers pushing these niche frameworks tend to mentally dismiss the actual costs and overhead incurred by using something like Elm.
It's tempting to categorize the struggles as "learning" and therefore try to pretend it doesn't count as lost time, but at the end of the day if your team has to spend extra cycles doing extra things just to accomplish basic tasks, it's a drag on productivity.
whateveracct 2021-08-18 21:28:25 +0000 UTC [ - ]
But if you can't afford for ANY time to not be spent directly on the business, don't do FP. Sounds like a pretty brutal way to work.
FP has _throughput_ benefits, but may come with _latency_ hiccups while your team climbs the learning curve (which may include writing libraries.)
If you have frequent deadlines (or treat 2 week sprints as deadlines), then FP won't jive..and you probably have bigger pain points in your company than PL choice lol.
PragmaticPulp 2021-08-18 21:37:01 +0000 UTC [ - ]
This is the core point I was disagreeing with:
In my experience (yes, I have used Elm and I enjoy various functional languages), this payoff never comes. There's always something more that needs attention, needs another developer, needs to be refactored because we forgot a use case, and so on.
And also in my experience, by the time you've invested the years of effort required to fill in gaps in the public package ecosystem, it's time to move on to the next niche language trend. I'd rather invest our time and energy in mainstream languages that have staying power, where we're not obligated to carry large parts of the open-source ecosystem by ourselves.
whateveracct 2021-08-18 21:49:23 +0000 UTC [ - ]
But that was Haskell I guess. It's obviously not a "niche language trend" by now, so it was pretty clear it had staying power.
Definitely has paid off for me personally. My side projects move a lot faster and more stably now that I cut my teeth in production Haskell. A real free 10xer to my skills personally. And I gained the skills by getting my employer to finance my learning lmao.
KronisLV 2021-08-18 22:22:47 +0000 UTC [ - ]
This probably depends on the complexity of what you need to do, as well as how well you want to do it.
I've seen people writing their own packages and pieces of systems in months, to typically pretty underwhelming results. However when writing code with tests, proper documentation, getting started guides etc., then what you're saying does sound way more plausible, especially if scope creep of any sorts is also present.
Would you care to comment on what sorts of systems take years to properly develop, though? Because in my experience that could be applicable to very few software projects out there.
koonsolo 2021-08-19 03:43:50 +0000 UTC [ - ]
This is not a "discussion" question, but a "fill my blind spot" question.
I always read how good FP is, and how much better it handles all the complexity. Yet I never see it win from software written with state.
Is there any big and/or complex sofware written in FP that I am overlooking?
gen220 2021-08-19 12:08:47 +0000 UTC [ - ]
In business domains with strict audit requirements, it’s a peace of mind thing, to know that “side effects” (aka persistence and the mutation of persisted data) are constrained to a tiny and highly testable corner of your code base.
For OSS, the examples that spring to mind for me are RabbitMQ (Erlang) and Pandoc (Haskell).
whateveracct 2021-08-19 03:51:25 +0000 UTC [ - ]
If you want real production software, Starbucks Rewards is/was powered entirely by pure Haskell code and made big bucks
Software having complex state actually makes Haskell even better than the competition. Because most state has nuanced rules about its state transitions.
Haskell definitely has more of a learning curve when it comes to dealing with state, but that curve will guide you towards a ceiling mainstream languages can't even approximate.
vlunkr 2021-08-18 22:41:03 +0000 UTC [ - ]
What proof of this is there though? People have made the same claims about lots of things: FP, OOP, statically typed languages, dynamically typed languages, LISP variants, etc. The fact is, any of these solutions can work, and you can also write terrible code with any of them.
adamwk 2021-08-18 23:20:07 +0000 UTC [ - ]
razze 2021-08-19 14:21:46 +0000 UTC [ - ]
whateveracct 2021-08-19 04:02:32 +0000 UTC [ - ]
KronisLV 2021-08-18 22:14:45 +0000 UTC [ - ]
Maybe in the context of the parent comment this holds true, but in my experience this is like walking on a knife's edge.
There's the very distinct possibility that you'll end up with homebrew frameworks and libraries that are overcomplicated, buggy, not commented and exceedingly hard to work with. I've seen that happen many times and it makes me consider not just whether people want to do that, not whether people have the time to do that, but even whether it's possible for them to do.
In one project people wanted all of their front end components to be custom and as a consequence spent 3x-5x longer building everything, none of their components were Googleable for someone who's been onboarded and thus people forgot how they even work after 2 weeks of not editing them and had to rediscover that later. I tried adding a component sandbox/playbook to help them provide examples, but no one was interested in doing that when they were already behind the expectations of the business. Picking an off-the-shelf framework would have saved them all of these troubles. Maybe there were actual reasons behind the choice of approaching the project this way, apart from padding their resumes, however after inquiring about those, i didn't get a convincing response.
In another case, i had to work on a custom web back end framework, which had been developed by another company, in a country the language of which i don't speak. Curiously enough, all of their code comments were in this language, there yet again was a lack of any sorts of documentation, the implementation was obtuse, slow and any simple changes to the forms took days to implement properly, even when it would take around 30 minutes in established technologies. Furthermore, the actual framework hadn't received any updates in years and therefore i fear to think what sorts of security issues it had. An off-the-shelf framework would have at least been updated and probably would have more decent documentation.
In short:
aranchelk 2021-08-18 16:26:52 +0000 UTC [ - ]
This is an important point; I think it applies to varying degrees to any less popular language or framework. It’s a little worse with Elm because of the restrictions they’ve placed on JS interop. I'll add that unless you're very familiar with the framework/language you'll be using, it's pretty hard to estimate scope of work; you'll just encounter surprises during implementation along the lines of "wow I can't be believe they don't have a library for x." On the plus side, since the work of implementing these libraries is very generic with regard to any specific application, it's easy to delegate to other employees or contractors.
I’m currently working on a large PureScript project. At various times I’ve had to implement my own base libraries and components, but in many cases I’ve just been able to wrap existing JavaScript code. Some of the key libraries I use, which were developed by other community members are wrapped JavaScript libraries. This has been a pretty powerful mitigation strategy.
In the case of PureScript, I also have the benefit of reusing a substantial amount of front end code on the server. For me, on this particular project, the benefits of using a language with advanced features has far outweighed the above mentioned costs, but I think you've got to look at each situation differently and do that evaluation.
platz 2021-08-18 18:16:44 +0000 UTC [ - ]
aranchelk 2021-08-18 18:44:30 +0000 UTC [ - ]
I was completely sold on the Elm architecture, but I used Haskell too long to be comfortable working without typeclasses, so I went through a couple different elm-like frameworks written for PureScript. I settled on one only to later realize what (I think) people are talking about when they say "Elm doesn't compose", which is not well articulated in that statement. I take it to mean: you can never really deal with stateful components in isolation because they have to work off of a unified global data structure. I developed some new tech that makes different tradeoffs and it got me what I wanted.
I knew developing my own framework was going to add a lot of extra work: * Writing the framework (not too bad, actually) * Writing the reusable components and combinators (exactly what you'd expect)
By far he hardest part has been establishing patterns and best practices working with a new and different architecture, I struggled with that for a while.
I'm a strong believer in the points made in Graham's Beating the Averages (actually what brought me to HN) and in my case I'm establishing a tech stack for my current and future projects, so I believe the framework was a worthwhile investment.
mst 2021-08-18 21:15:09 +0000 UTC [ - ]
(apologies for the lumpy phrasing, insomnia is a pain)
aranchelk 2021-08-18 22:18:23 +0000 UTC [ - ]
I'm absolutely not an authority on Elm architecture, I just know that my experience doing stuff like forms with validation really sucked.
mst 2021-08-19 16:52:16 +0000 UTC [ - ]
Silhouette 2021-08-18 18:15:15 +0000 UTC [ - ]
I think you've just defined a pretty good benchmark for when it's sensible to consider a less popular choice. Are you familiar enough with it to be confident of coming out ahead by using it? Perhaps you have a backup plan like the interop you mentioned if some functionality is missing. Perhaps the tool is so much more productive in general that you are reasonably confident any extra development work to fill in the gaps will be outweighed by the overall benefits. But there should be some clear reason you think the risk is justified.
dimitrios1 2021-08-18 15:56:53 +0000 UTC [ - ]
Good. The longer I do this, the longer I realize that unless your in a race-to-the-bottom industry (something like vying for eye balls to increase ad spend), then this is categorically a bad thing. I would prefer the quality of engineering required in knowing how to do some of these things yourselves.
Take your time. Understand what you are doing. Some of the world class technologies we all know and use daily use minimal dependencies.
And with more malicious code entering more package repositories, it might be apt advice more than ever today.
pjlegato 2021-08-18 17:00:35 +0000 UTC [ - ]
That never happens in the real world. One always has limited time to produce a viable product. There is always some extrinsic constraint to how much time can be spent taking your time and understanding what you're doing.
Moreover, if you are operating in any commercially viable product space, you're always competing against other firms for finite market share. If it takes x years to ponder and understand how to build and ship a masterful feat of engineering, while some other company ships a "sort-of-works" product with bugs and engineering flaws in <<< x years, the other company will usually win in the marketplace.
Your company usually goes bankrupt, and all the engineers will complain at their next jobs about what a wonderfully designed engineering system they were building, and how awful it is that nobody appreciates such things these days.
0xFACEFEED 2021-08-18 18:09:17 +0000 UTC [ - ]
While this is obviously true, I don't think it depicts the actual decision making process that leads to messy codebases and crappy products. In my experience lack of experience and/or laziness play a big part.
A competent tech lead that's passionate about quality AND is willing to be annoying for the greater good makes an enormous difference. I'm talking multiple orders of magnitude difference.
It's the difference between spinning up a k8s cluster + service mesh vs tiny single server vps with basic failover. The former is thousands of hours of dev time across multiple disciplines while the latter a seasoned engineer can handle by themselves.
PragmaticPulp 2021-08-18 18:14:24 +0000 UTC [ - ]
This is precisely why I try to interview tech leads about what they shipped rather than what they built. There are a lot of otherwise very talented developers out there who will spend years playing around in your codebase, writing beautiful code, but not actually shipping anything useful. Replacing them with shipping-focused engineers, even if they're not as technically competent, usually results in big productivity boosts.
This isn't a popular opinion among developer communities, but it's a common theme in the management forums I'm part of. It's important to have fun and budget some time for things like open-source contributions and library building, but the top priority must always be on shipping product.
Silhouette 2021-08-18 17:59:11 +0000 UTC [ - ]
How often does substandard technology and technical debt become a drag on a business not long after that first move, allowing someone else to overtake because the poorly built system couldn't scale to production levels or wasn't adaptable enough for changing requirements or failed so often that the early users drifted away? How often do we see developers advocating shortcuts and showing limited understanding of basic software development or computer science ideas, only to see the product they work on being rewritten within a year or two, or the whole team shut down?
You can try to be fastest always. You can often succeed, at first, if you take enough shortcuts. But you can't sustain that pace without enough quality in your people and your code. Planning to throw each implementation away and rewrite with more resources every year or two is a very unicorn-like strategy. It reminds me of VCs whose strategy is to invest liberally, who are fully aware that most of those investments won't work out but they're hoping for one or two in each batch to become the next big hits.
Real engineering isn't done in a vacuum and its goal isn't perfection. Real engineering takes issues like costs and timescales and staffing into account and aims to find a solution that is good enough on all counts. But it still has to be good enough. Producing junk but quickly and cheaply is an effective strategy until it's not and the success of any product using that strategy comes down to little more than the luck of the draw.
pjlegato 2021-08-18 18:11:52 +0000 UTC [ - ]
My post was addressing the common case where an engineer seems to ignore the 'resource constraints' side of the equation altogether.
Balancing these factors is more art than science. No two projects have the same set of resource constraints, nor the same set of engineering challenges. Luck is a big factor. The solution depends heavily on the exact details of each particular case.
JamesSwift 2021-08-18 18:52:21 +0000 UTC [ - ]
Silhouette 2021-08-18 19:09:26 +0000 UTC [ - ]
IME retrospectives rarely sound like "We hired a team of strong developers, they did a solid job, but then the business failed as a result". The kind of developers who are strong enough to do a solid job are probably also experienced enough to recognise the other considerations in play and adapt if necessary.
PragmaticPulp 2021-08-18 17:05:41 +0000 UTC [ - ]
Realistically, a couple of engineers writing a library from scratch isn’t going to be higher quality than adopting a mainstream, battle-tested library that accomplishes the same thing.
Writing your own implementations of everything can be fun, but it’s not possible to compete with all of the iterations and reviews that a mainstream library collects over time.
aszen 2021-08-18 18:35:15 +0000 UTC [ - ]
An open source library is necessarily generic and has to be battle tested to make sure it fulfills all use cases, while the library you write only has to cover your own needs that makes it easier to understand, extend and debug
xupybd 2021-08-19 03:05:50 +0000 UTC [ - ]
pkolaczk 2021-08-18 19:31:00 +0000 UTC [ - ]
Also many "battle-tested" libraries are not really very high quality - they all have bugs, unnecessary complexity and technical debt. Higher degree of testing they get is often offset by the higher number of feature requests, and more features means more complexity and more bugs.
And in reality I saw it many times when a niche library written by a solo developer is of a higher quality than a super popular behemoth written by hundreds of developers over 10 years.
dimitrios1 2021-08-18 18:07:58 +0000 UTC [ - ]
ModernMech 2021-08-18 18:26:23 +0000 UTC [ - ]
- ubiquitous things, like data structures
- hard to get right things, like time
- implementations of specs, like Unicode
- hardware interfaces, like CUDA
For everything else, I'll take the above and roll my own solution.
alephu5 2021-08-18 22:54:47 +0000 UTC [ - ]
PhineasRex 2021-08-18 23:40:23 +0000 UTC [ - ]
dimitrios1 2021-08-18 19:58:50 +0000 UTC [ - ]
scotttrinh 2021-08-18 20:17:44 +0000 UTC [ - ]
> - ubiquitous things, like data structures
There are a few basic data structures in JS, but almost everything else is in user-land.
> - hard to get right things, like time
Date is a notoriously bad API in JavaScript.
- implementations of specs, like Unicode
We just get a String type in JavaScript which is UTF-16, so...
dimitrios1 2021-08-19 13:57:23 +0000 UTC [ - ]
Well, no, we aren't. We are talking about the Elm language, which compiles to JavaScript.
There are also other excellent languages that target JavaScript that have these things.
k__ 2021-08-18 18:12:45 +0000 UTC [ - ]
I've also seen many developers for years adopting mainstream libraries and frameworks wrongly.
The atrocities I've seen built with Ember, Rails, Angular, and the like.
Often these people built their own (albeit less powerful) libraries and could work much better with them.
KronisLV 2021-08-18 22:34:25 +0000 UTC [ - ]
In my experience, if someone fails at using mainstream libraries, they will also likely fail in creating their own, at least if it is to later be used and maintained by anyone else successfully.
k__ 2021-08-18 22:54:16 +0000 UTC [ - ]
The problem with mainstream libraries is to grasp the mental model of their creators.
I met a bunch of developers who understood software design patterns as they are taught in the GoF book, but couldn't see them when applied in a framework/library. Often this was because the design patterns weren't used 1:1 or framework creators simply used the wrong name for a pattern.
aszen 2021-08-18 18:44:21 +0000 UTC [ - ]
Silhouette 2021-08-18 18:06:19 +0000 UTC [ - ]
That's true but the vast majority of what you find on NPM is not mainstream, battle-tested libraries.
Libraries that do clear that bar tend to be widely useful but that suggests generality you won't necessarily need for any single use case. A couple of good engineers might struggle to beat a well-established open source library at everything it does, but that is rarely what they are trying to achieve. They just need something that is better for their own specific needs at that time, which might be a useful and realistic target.
mwcampbell 2021-08-18 18:18:36 +0000 UTC [ - ]
It's not that simple. I realize this may be uncommon, but it's possible to work on a product that is truly worthwhile, that improves peoples' lives, and whose target users urgently need a solution to the problem you're solving. I recently developed a product that I believe meets this description (I won't plug it here). I chose Elixir for the web application. While I think that's a defensible choice, given the real-time nature of the application, I sometimes wonder if I would have been better off choosing a more mainstream language -- one with an official Stripe client library, for one thing. Any day I spent unnecessarily reimplementing something because I chose Elixir is a day that the target users couldn't benefit from my product. And, bearing that in mind, I should get back to work.
aszen 2021-08-18 18:32:01 +0000 UTC [ - ]
WJW 2021-08-18 20:44:57 +0000 UTC [ - ]
aszen 2021-08-19 10:51:39 +0000 UTC [ - ]
Choosing non-popular languages is a trade off yes but not as much as people think especially if you have a good team willing to learn them.
There are also benefits apart from technical ones like better job retention and attracting finer talent without having to filter hundreds of resumes. I will say if your business is made around hiring and making anyone work of the shelf then it's a bad idea.
xupybd 2021-08-19 03:03:23 +0000 UTC [ - ]
It gets really hard to maintain after 10 - 15 years. I wish we had rolled our own libraries for some of the simpler functions. Even in PHP this would have made life so much better.
2021-08-18 16:01:41 +0000 UTC [ - ]
lhorie 2021-08-18 19:39:36 +0000 UTC [ - ]
I dunno, having seen both sides, there are pros and cons to each.
Teams that reach for libs quickly often think in terms of libraries instead of solutions (one recent example was some folks who were asking for my advice on some over-engineered client-side PDF generation thing, and me suggesting `window.print()` as a solution, considering this was for an internal tool and you effectively want print stylesheets anyways), and often use them as crutches due to a self-fulfilling cycle of "I don't know how to do X, let's use a library so I never need to find out" (and then pulling in a huge lib to do the job of a literal one-liner regex - `uuid.validate()`, looking at you). In my experience, they also often end up buried by their own complexity due to gluing too many things together. But at the same time, it's hard to argue with the ease with which one can plop a modal dialog or a calendar or a collapsible table in a React app.
I find that teams working with more exotic technologies tend to be more creative with solutions (e.g. "oh there's no zoomable map UI lib bindings, so let's ask ourselves, do we really need a map library for that contact us page or is a static jpg good enough?") and a have a deeper appreciation for how hard things are to implement. But conversely, UX can suffer from too much "creativity". For example, if care is not taken w/ accessibility concerns for some UI element. Or, as you said, things just take longer to ship because people need to reinvent wheels.
theobeers 2021-08-18 16:17:44 +0000 UTC [ - ]
edit: Ah, hold on; I just got to where they comment on this. “TypeScript, which adds optional static typing to JavaScript and is probably one of the best things to happen to JavaScript, can partially mitigate the issues with the JavaScript dynamic type system. But being a superset of JavaScript it needs to compromise on elegance and simplicity. It also has several ‘blind spots.’” etc. I don’t know that I’m 100% convinced.
wk_end 2021-08-18 20:34:59 +0000 UTC [ - ]
I'm at a company that's transitioning to TypeScript, and the reality is that you can't just flip a switch and have a well-typed codebase: if we just turn `strict` on, `tsc` gives us thousands and thousands of errors. And as we've gone through trying to annotate things, it's clear that in order to get various components to a state where they're properly type-safe, we'll need to almost completely rewrite them.
Compared to Rakuten, our codebase isn't even that huge or legacy - it's often very poorly written, but it's less than 50K lines and less than a couple of years old. No doubt the situation for Rakuten would be even worse; I'm sure huge swaths of their code would need to be trashed anyway.
If TypeScript is ultimately going to force you to rewrite - and still leave you with a less-robust solution - I could see why starting with a clean-slate with Elm would be appealing.
cardanome 2021-08-18 16:59:55 +0000 UTC [ - ]
Also TS is just part of a potential solution while Elm comes with all batteries included. You still have to set up your code formater, liner, decide on a framework, state management library and so on and so on. With Elm, you just use elm-format. No arguing about code style, not arguing about how structure your code. There is only way to do it. It is not only a language but a framework. You get everything you need out need out of the box.
leshow 2021-08-19 14:25:11 +0000 UTC [ - ]
> You get everything you need out need out of the box.
This is specious. There's lots of comments about how you don't get everything out of the box and for the parts that are missing it's a pain. Perhaps your particular use cases are covered, that's great.
toastal 2021-08-18 17:19:25 +0000 UTC [ - ]
mjaniczek 2021-08-18 20:05:22 +0000 UTC [ - ]
Is this your experience writing Elm apps in production? I am writing large Elm apps in production and I'm having very different experience to what you just described.
aszen 2021-08-18 18:42:31 +0000 UTC [ - ]