221
Why indeed (lemmy.ml)
you are viewing a single comment's thread
view the rest of the comments
[-] masterspace@lemmy.ca 16 points 1 week ago* (last edited 1 week ago)

Because storage is cheap, so it's not worth optimizing that heavily for, because the optimization creates a huge amount of headaches.

There's a reason that today you can just download an app, and it just installs, runs, and uninstalls itself cleanly.

There's no fighting with dependencies, or installing versions of libraries or frameworks before you can install an app, or having apps conflict with other apps, or having bits of app installations lying around conflicting with things.

That's because we used to spend a lot of time and effort making sure that only a single copy of each dependency was installed on a system. If two apps both relied on the same library, one would install it, and the other would then be dependent on it as well and not install its own copy. If the original is removed you have a problem. If it thinks something else is dependent on its asset still and doesn't remove it when it should you've got a problem. If they were both dependent on different major versions of a library, you could run into conflicts and compatibility issues (hello dll hell). Either the apps would have to manage all that, or the OS would, or eventually the user often would.

Now every app just bundles all its dependencies with it. It means the app comes as a clean bundle, there's no conflicts, it can install cleanly, and there's so much less time spend on packaging apps and debugging various system configurations.

Quite frankly this makes way more sense as a model for distributing anything. Yes it costs more in storage, but it pays off massively in resiliency and time savings for everyone.

Also, unless everything is done with vectors, high def image / video assets are not small and can very quickly add up.

[-] yogthos@lemmy.ml 12 points 1 week ago

Except that it's not just storage, but also increased memory footprint and CPU usage in a lot of cases. Take something like Slack which is a huge resource hog.

Electron. Many apps nowadays are just headless browsers and browsers are huge and complex. It's nice from a development perspective, because you can (re)use web tools for desktop apps but it's very resource hungry.

[-] yogthos@lemmy.ml 5 points 1 week ago

It's worth noting that it doesn't have to be that way. Take Tauri as an example of leveraging the benefits of web stack development, and having an efficient runtime under the hood.

[-] masterspace@lemmy.ca -1 points 1 week ago* (last edited 1 week ago)

Yes, and now you can't test your application before shipping it because who knows what browser engine will actually run it.

You could develop it on Windows and have it completely break for every single Mac user when it executes in Safari and have literally no way of knowing or testing that ahead of time.

[-] yogthos@lemmy.ml 7 points 1 week ago

I mean you would just test on each platform, which you should be doing regarding of what you're developing with. Also worth noting that web standards are a thing, and vast majority of apps aren't so complex that they would run into edge cases between browser engine implementations.

However, this isn't an inherent problem since you could build something like Tauri and package its own lean rendering engine with it. Sciter-js is an example of this approach. Other examples can be seen with React Native and Proton. The main point here is that the bloat the Electron brings to the table is wholly unjustified, and far more efficient approaches are possible.

[-] masterspace@lemmy.ca -3 points 1 week ago* (last edited 1 week ago)

I mean you would just test on each platform, which you should be doing regarding of what you're developing with.

Yes, except the platform your developing for with Electron is the browser engine you ship alongside it, so you are constantly testing it and it will always work.

With Tauri the platform your developing for is now whatever the underlying OS chooses to use to render it's WebView. It is flat out impossible to test for every os and WebView so you have no guarantee that your application will even render once it's installed.

And again, if you develop on a Windows or Linux machine, there is flat out no way to test on Safari without buying a Mac, but you can reliably expect your Electron app to just work.

Also worth noting that web standards are a thing, and vast majority of apps aren't so complex that they would run into edge cases between browser engine implementations.

Lmao. Bruh, I'd like to introduce you to this little known WebView called Safari.

The vast majority of web apps will run into compatibility issues between safari, Firefox, and chrome. There is nowhere close to enough standardization for that.

However, this isn't an inherent problem since you could build something like Tauri and package its own lean rendering engine with it. Sciter-js is an example of this approach. Other examples can be seen with React Native and Proton. The main point here is that the bloat the Electron brings to the table is wholly unjustified, and far more efficient approaches are possible.

Lol, you've clearly never installed a React Native app if you think there's no bloat.

No, the point is that you want it to be unjustified but it's not. Electron works great, is incredibly easy to setup and ship with extremely little overhead beyond storage. The opportunity cost of solutions that don't bundle dependencies are almost never worth it.

There's a reason the most popular IDE used by virtually every software developer these days is built using Electron.

[-] yogthos@lemmy.ml 1 points 1 week ago

Lmao. Bruh, I’d like to introduce you to this little known WebView called Safari.

Bruh, I've been developing web apps for over a decade now. You don't have to introduce me to anything. The reality is that most apps aren't that complex and if you're using something like React, a lot of the details are already handled for you.

The vast majority of web apps will run into compatibility issues between safari, Firefox, and chrome. There is nowhere close to enough standardization for that.

Sounds like skills issue there bud.

Lol, you’ve clearly never installed a React Native app if you think there’s no bloat.

We're comparing with Electron here lmfao.

No, the point is that you want it to be unjustified but it’s not. Electron works great, is incredibly easy to setup and ship with extremely little overhead beyond storage. The opportunity cost of solutions that don’t bundle dependencies are almost never worth it.

If by works great you mean hogs resources like no tomorrow and is able to bring modern hardware to its knees to render a simple crud app, then sure.

There’s a reason the most popular IDE used by virtually every software developer these days is built using Electron.

Vast majority of apps people make aren't nearly as complex as an IDE.

[-] masterspace@lemmy.ca -1 points 1 week ago* (last edited 1 week ago)

Bruh, I've been developing web apps for over a decade now. You don't have to introduce me to anything. The reality is that most apps aren't that complex and if you're using something like React, a lot of the details are already handled for you.

XD XD XD

You mean ... Webpack? React handles nothing of web compatibility for you.

We're comparing with Electron here lmfao.

I literally quoted you talking about using react Native instead. Try and remember what you wrote.

If by works great you mean hogs resources like no tomorrow and is able to bring modern hardware to its knees to render a simple crud app, then sure.

Oh yeah, that's how everyone feels about VS Code. What a horrendous resource hog! No developer would ever use it!

/S

Again, there are opportunity costs to other frameworks. There is a reason Electron is so popular and it's not because it's terrible.

[-] yogthos@lemmy.ml 1 points 1 week ago

I literally quoted you talking about using react Native instead. Try and remember what you wrote.

I gave React Native as an example of an alternative approach to using a browser engine for rendering. Try to work on that reading comprehension of yours.

Oh yeah, that’s how everyone feels about VS Code. What a horrendous resource hog! No developer would ever use it!

A lot of people do feel that it's a resource hog because well it is a resource hog. The fact that you don't understand that is truly incredible.

Again, there are opportunity costs to other frameworks. There is a reason Electron is so popular and it’s not because it’s terrible.

Yes, there are opportunity costs. I understand perfectly well why Electron is popular. It makes it easier to crap out something that sort of works. There's a huge benefit to the developer and a huge cost to the user.

[-] masterspace@lemmy.ca 0 points 1 week ago* (last edited 1 week ago)

gave React Native as an example of an alternative approach to using a browser engine for rendering. Try to work on that reading comprehension of yours.

Yeah, I'm aware. I pointed out why your example was dumb.

A lot of people do feel that it's a resource hog because well it is a resource hog. The fact that you don't understand that is truly incredible.

No, badly written apps are badly written, and perennially online nerds coalesce around hating the same things for validation, which in this case is Electron.

Yes, there are opportunity costs. I understand perfectly well why Electron is popular. It makes it easier to crap out something that sort of works. There's a huge benefit to the developer and a huge cost to the user.

You keep ignoring the point that VSCode, amongst many other great apps, is written with Electron.

Youre bitching about the fact the fact that Electron lowers the barrier of entry, and confusing that for Electron being fundamentally bad.

i.e. Discord doesn't suck because it's written with Electron, it sucks because it's developers / product managers never prioritized making it not suck.

[-] yogthos@lemmy.ml 2 points 1 week ago

Yeah, I’m aware. I pointed out why your example was dumb.

All you've pointed out is that you're incapable of understanding the point being made. The point again, is that you don't need a full blown browser engine to get the benefits of having a consistent platform that's easy to develop against. If people cared about performance, it would be possible to make a lean engine that does much of what Electron does without the bloat.

No, badly written apps are badly written, and perennially online nerds coalesce around hating the same things for validation, which in this case is Electron.

The fact that you can't even acknowledge that Electron is bloated compared to a native app is incredible.

You keep ignoring the point that VSCode, amongst many other great apps, is written with Electron.

I'm not ignoring anything. I'm pointing out the cost here. Compare with Emacs as an example.

Youre removed about the fact the fact that Electron lowers the barrier of entry, and confusing that for Electron being fundamentally bad.

I'm not doing anything of the sort. I'm pointing out that Electron as it exists today is bloated. I'm not against the concept in the slightest, and this whole discussion was me trying to explain to you how similar benefits can be achieved without the overhead. Clearly that's just a little too hard for you to wrap your head around though.

[-] masterspace@lemmy.ca -1 points 1 week ago* (last edited 1 week ago)

No, because you haven't. You've brought up examples that all bring their own overhead, complications, and testing issues.

Once again, at a fundamental level, if I develop an Electron app on Linux or Windows, I can generate an installer and am basically guaranteed that it will work on MacOS because the Electron rendering stack works on MacOS and I am shipping my full rendering stack alongside my app.

A WebView solution that uses the system's WebView cannot possibly provide that.

A specifically versioned runtime like Java can potentially provide that, though if you were to expand Java to support the out of the box high level rendering of html / CSS then you're basically turning the JRE into the size of a full browser engine anyways, especially if you were to expand it to support a pleasant and flexible language like JavaScript.

And again, you're refusing to acknowledge that VSCode is built in Electron, and is not a resource hog, despite being possibly the most powerful Electron program most people will run, once again, showing that Electron is not that much of a resource hog, badly coded web apps are.

I fully acknowledge that Election apps use more storage and slightly more ram than equivalents written in Native Languages, but if you're experiencing actual slow downs due to them, then it's probably because they're badly written.

And I reject the idea that the opportunity cost of slowing down software development is worth it. App distribution used to be over optimized for efficiency rather than resiliency.

[-] yogthos@lemmy.ml 2 points 1 week ago

No, because you haven’t. You’ve brought up examples that all bring their own overhead, complications, and testing issues.

Every approach has its trade offs. I've explained to you repeatedly and in detail how what Electron does can be improved. It's clear at this point that I'm not going to get through here.

Once again, at a fundamental level, if I develop an Electron app on Linux or Windows, I can generate an installer and am basically guaranteed that it will work on MacOS because the Electron rendering stack works on MacOS and I am shipping my full rendering stack alongside my app.

You absolutely do have to test Electron apps on each platform. However, the point once again, is that as long as you package the rendering engine with the app it's going to have the same benefits.

A specifically versioned runtime like Java can potentially provide that, though if you were to expand Java to support the out of the box high level rendering of html / CSS then you’re basically turning the JRE into the size of a full browser engine anyways, especially if you were to expand it to support a pleasant and flexible language like JavaScript.

You don't have to extend the JVM for anything and there are plenty of very nice toolkits available such as https://github.com/HumbleUI/Skija/

The JVM supports far better languages than Js as well. I work with Clojure and it's straight up better experience in every single way. Not to mention that your development process is fully interactive where you connect the editor to a running instance of the application and you can evaluate any code you want as you write it within the context of the app you're building. The tooling around Js is incredibly primitive in comparison.

However, there are lean alternatives to Electron available for JS as well. Scriter-js is one example which provides a far leaner runtime.

And again, you’re refusing to acknowledge that VSCode is built in Electron, and is not a resource hog, despite being possibly the most powerful Electron program most people will run, once again, showing that Electron is not that much of a resource hog, badly coded web apps are.

It absolutely is a resource hog compared to something like Emacs, and it's not even comparable.

I fully acknowledge that Election apps use more storage and slightly more ram than equivalents written in Native Languages, but if you’re experiencing actual slow downs due to them, then it’s probably because they’re badly written.

LMFAO understatement of the century there.

And I reject the idea that the opportunity cost of slowing down software development is worth it. App distribution used to be over optimized for efficiency rather than resiliency.

That's just an inane straw man you're using. What I'm actually saying is that you CAN have the benefits of Electron and an efficient runtime. These things are in no way at odds with each other. The fact that you can't understand that is incredible.

[-] masterspace@lemmy.ca 1 points 1 week ago* (last edited 1 week ago)

Ok, I see what you're saying ,but from what I can see, if you were to scale a sciter app to the level of VSCode, it is not going to use any less resources.

Yes sciter is smaller for a simple calc app, but once you have multiple ui panes running in different threads, plus a backend server, it looks like it would scale it exactly the same resource usage as Electron.

[-] yogthos@lemmy.ml 0 points 1 week ago

It would would use less resources because it's a more optimized runtime. In fact, the more UI panels and other elements you have in the app, the more savings you'd be making proportionally. Even when faced with a concrete example of being wrong, you're still digging. 🤦

[-] masterspace@lemmy.ca 1 points 1 week ago

I DECLARE A MORE OPTIMIZED RUN TIiIIIIME

[-] yogthos@lemmy.ml 0 points 1 week ago
[-] masterspace@lemmy.ca 0 points 1 week ago* (last edited 1 week ago)

No, you just can't recognize when you're wrong and someone is kindly trying to meet you half way anyways.

[-] yogthos@lemmy.ml 0 points 1 week ago

The fact that you're faced with an example of a much more optimized runtime and still can't understand that you're wrong is frankly hilarious. Maybe once you get a bit of programming experience under your belt you'll be able to hold a meaningful discussion on the subject.

[-] TimeSquirrel@kbin.melroy.org 5 points 1 week ago

It's also because we started doing shit like using JS in places it really shouldn't belong. Half the programs on my PC are just webapps running in a sandbox environment, instead of using systems languages like C/C++ directly like was the case 15-20 years ago. Abstractions on top of abstractions on top of abstractions. JS was fine for embellishing elements of a web site and facilitating AJAX, it should have never been turned into an app language.

That'd be like if interpreted BASIC was taken seriously in the 80s as more than just a toy and the majority of popular software was written in it. We'd rightfully question WTF society was thinking.

[-] masterspace@lemmy.ca 1 points 1 week ago* (last edited 1 week ago)

No we wouldn't, and this is a crazy take when like half of Linux runs on interpreted python.

You're min/maxing for things that don't matter. You know what does matter? User facing features. You know what language in unquestionably the fastest to produce user facing features in? JavaScript/HTML/CSS.

If you want to optimize for performance you can do so after by moving things server side, writing them in web assembly, or offloading them onto other threads.

There's also massive opportunity cost in a) programming in low level languages, and b) having every developer have to learn a low level language. There's a reason that we don't all code in assembly any more.

[-] JoeyJoeJoeJr@lemmy.ml 3 points 1 week ago

It's also worth noting apps have to ship higher resolution assets now, due to higher resolution displays. This can include video, audio, images, etc. Videos and images may be included at multiple resolutions, to account for different sized displays.

For images, many might assume vectors are the answer, but vectors have to be rendered at runtime, which increases startup time in the best case scenario, and isn't even always supported on all platforms, meaning they have to be shipped alongside raster assets of a few different sizes, further increasing package bloat. And of course the code grows to add the logic to properly handle all the different asset types and sizes.

All this (packaging dependencies, plus assets/asset handling) to say it isn't always malware, ads, electron, etc. Sometimes it's just trying to make something that looks nice and runs well (enough) on any machine.

[-] YellowTraveller@lemm.ee 0 points 1 week ago

A good package manager like those commonly used on Linux solves this problem

this post was submitted on 21 Mar 2025
221 points (96.6% liked)

Programmer Humor

34766 readers
313 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS