this post was submitted on 23 Sep 2024
68 points (98.6% liked)

Firefox

17815 readers
43 users here now

A place to discuss the news and latest developments on the open-source browser Firefox

founded 4 years ago
MODERATORS
 

An old article but provides a detailed view on the choice of removing the old XUL addons

top 5 comments
sorted by: hot top controversial new old
[–] Dirk@lemmy.ml 29 points 1 month ago

XUL was HORRIBLE to write, implement, and debug. Been there, done that. It was also 0% portable.

WebExtensions (even if there are some technical limitations and some browser manufacturers decided to intentionally cripple some of the APIs) are in general so much better. You have proper toolchains for development, translations, testing, and publishing. And it is pretty much portable to all browsers. You don't even have to port anything 99% of the time because it's just compatible.

[–] jimmydoreisalefty@lemmy.world 23 points 1 month ago* (last edited 1 month ago) (1 children)

TIL.

Thanks for sharing!


Edit: added quote below

By design, WebExtensions is more limited than the promiscuous extension mechanism. By design, it also works better. Most of the Firefox development tax has disappeared, as only the WebExtensions API needs to be protected, rather than the entire code of Firefox. Most of the maintenance tax has disappeared, as the WebExtensions API are stable (there have unfortunately been a few exceptions). It is also much simpler to use, lets add-on developers share code between Firefox and Chromium add-ons and should eventually make it easier to write extensions that work flawlessly on Desktop and Mobile.

[–] Chewy7324@discuss.tchncs.de 11 points 1 month ago

With uBlock Origin and many other extensions working (almost) flawlessly on mobile, I'd say they were spot on. Almost, because some aren't comfortable to use because they aren't made with touch and small a screen in mind.

[–] mnmalst@lemmy.zip 12 points 1 month ago (1 children)
[–] Blisterexe@lemmy.zip 4 points 1 month ago

But totally worth the read