Un des points forts de Firefox face à Internet Explorer était sa multitude d’extensions disponibles pour le personnaliser. David Teller nous explique pourquoi Mozilla a dû modifier à deux reprises le système d’extensions pour pouvoir faire évoluer Firefox. Nous vous en proposons une traduction dans la suite de cette dépêche.
Cette dépêche est sous licence CC BY‑NC 4.0 (la licence originale de l’entrée de blog).
Sommaire
Pourquoi Mozilla a supprimé les extensions XUL ?
En résumé : Firefox avait un excellent mécanisme d’extension fondé sur XUL et XPCOM. Ce mécanisme nous a longtemps bien servi. Malheureusement, en termes de maintenance, ce mécanisme s’est accompagné d’un coût toujours croissant, aussi bien pour les développeurs de Firefox que pour ceux des extensions. D’un côté, ce coût croissant a progressivement tué tout effort pour rendre Firefox sécurisé, rapide ou pour essayer de nouvelles choses. À la longue, ce coût toujours croissant a progressivement tué la communauté des développeurs d’extensions. Finalement, après des années perdues en essayant de protéger ce vieux mécanisme d’extension, Mozilla a pris la décision difficile de le supprimer et de le remplacer par les API WebExtensions, qui sont moins puissantes, mais beaucoup plus maintenables. Grâce à ce choix, les développeurs de Firefox peuvent à nouveau faire les changements nécessaires pour améliorer la sécurité, la stabilité ou la vitesse.
Ces derniers jours, j’ai eu des discussions avec les utilisateurs de Firefox, en essayant de séparer les faits des rumeurs à propos des conséquences des licenciements d’août 2020 par Mozilla. Un des sujets qui est revenu plusieurs fois a été la suppression des extensions XUL lors du passage à Firefox Quantum. J’étais très surpris de voir que, des années après, plusieurs membres de la communauté se sentent encore blessés par ce choix.
Et puis, comme quelqu’un l’a indiqué sur Reddit, j’ai réalisé que nous n’avions toujours pas pris le temps d’expliquer en détail pourquoi nous n’avions pas eu d’autre choix que de supprimer les extensions XUL.
Donc, si vous êtes prêts pour plonger dans les entrailles des extensions et de Gecko, j’aimerais saisir cette opportunité d’essayer et de vous donner un peu plus de détails.
À propos des extensions laxistes, JetPack et des WebExtensions
Depuis très longtemps, Firefox était composé d’un très petit noyau au-dessus duquel toutes les fonctionnalités étaient développées sous la forme d’extensions. Beaucoup de celles-ci étaient écrites en C++, d’autres en JavaScript et beaucoup utilisaient le langage d’interface XUL et le langage de liaison (binding) XBL. Les codes C++ et JavaScript étaient connectés grâce à une technologie nommée XPCOM. Dès qu’un développeur d’extension souhaitait personnaliser Firefox, c’était simple et extrêmement puissant, puisque les outils utilisés pour personnaliser Firefox étaient exactement les mêmes outils que ceux utilisés pour construire Firefox.
C’est ainsi que la restauration de session (la technologie qui vous permet de reprendre Firefox où vous en étiez la dernière fois, même en cas de plantage) ou la barre de recherche ont été originellement ajoutés dans Firefox, ainsi que d’autres fonctionnalités. C’est cette technologie qui fait fonctionner Firefox et Thunderbird. C’est comme ça que des outils comme Songbird (une alternative libre à iTunes) ou Instantbird (un client de messagerie instantanée) ont été développés. C’est aussi comme ça que j’ai personnalisé Firefox pour le transformer en lecteur e‑book il y a longtemps. Et c’est ainsi que des milliers d’extensions pour Firefox ont été développées.
Beaucoup de monde appelle ce mécanisme d’extension les « extensions XUL », ou parfois « extensions XPCOM », et j’utiliserai ces deux termes dans la suite de ce billet, mais j’ai tendance à le décrire comme le « mécanisme d’extension laxiste », pour plusieurs raisons :
- très rapidement, les développeurs de modules complémentaires ont réalisé qu’ils pouvaient casser n’importe quoi dans le système, y compris d’autres modules complémentaires et Firefox lui-même, et que, souvent, il n’y avait aucun moyen de le prévenir ;
- de même, n’importe quel développement de Firefox pouvait casser des modules complémentaires, et souvent il n’y avait aucun moyen de l’empêcher ;
- de plus, certains des changements que Firefox nécessitait pour être aussi rapide, stable et sécurisé que possible allaient rapidement casser la plupart des modules complémentaires et probablement tous les modules complémentaires à long terme ;
- ah, et bien sûr, comme les modules complémentaires pouvaient tout faire, ils pouvaient très facilement accéder au système d’exploitation, voler des mots de passe ou encore prétendre être votre banque.
Note : Après avoir lu dans les commentaires que certains utilisateurs ne se soucient apparemment pas de la sécurité, laissez-moi ajouter qu’être sécurisé est un point très très important pour Mozilla et que ça l’a été dès le début. Indépendamment des extensions, ne pas avoir de sécurité signifie que, un jour ou l’autre, une technique sera développée pour voler les mots de passe des utilisateurs et les utiliser pour détourner leurs comptes bancaires – et que cette technique sera vendue à gauche et à droite pour finir par être utilisée partout sur le Web. Les développeurs de Firefox se battent contre cette menace quotidiennement avec toutes sortes de moyens comme les revues de code, la programmation défensive, les investigations de scénarios de plantage, plusieurs types d’isolation (sandboxing), l’analyse statique, des langages protégeant la mémoire… Par conséquent, pour Mozilla, si une fonctionnalité nous empêche d’obtenir une meilleure sécurité, nous choisissons toujours la sécurité à la place des fonctionnalités.
Je reviendrai en détail sur ces points plus tard. Pour le moment, il suffit de dire qu’il était clair depuis longtemps pour les développeurs de Firefox (au moins depuis 2010) que cette situation était intenable. Ainsi, Mozilla a présenté un plan de secours appelé Firefox Jetpack.
Firefox Jetpack était une manière très différente d’étendre Firefox. C’était bien plus propre. Il y avait enfin un mécanisme de permissions (un point qui a été suggéré avant même que Firefox ne s’appelle Firefox et qui était considéré généralement comme trop difficile à implémenter). Dès le départ, les extensions ne pouvaient plus endommager les autres extensions ou Firefox (si je me souviens bien, c’était encore parfois possible en utilisant le service Observer, mais il fallait faire exprès de le faire), ça utilisait intensivement la programmation asynchrone (ce qui est très bien pour obtenir la sensation de performances élevées), et, grâce au fait que c’était une API délimitée, ça pouvait être testé, ce qui signifiait que, quand les développeurs de Firefox cassaient les extensions, ils pouvaient s’en rendre compte immédiatement et réparer les problèmes ! Jetpack représentait plusieurs énormes pas en avant. La contrepartie était une API bien plus limitée, mais dans la plupart des cas, le jeu semblait en valoir la chandelle.
Malheureusement, il y a eu des incompatibilités inattendues entre la conception de Jetpack et certains des changements majeurs nécessaires dans Firefox. Je ne sais pas exactement ce qu’était cette incompatibilité, mais nous avons été obligés d’abandonner Jetpack. À la place, nous avons introduit les WebExtensions. Dans l’ensemble, les WebExtensions avaient un objectif similaire aux extensions Jetpack, avec également une API restreinte et l’avantage supplémentaire qu’elles pourraient fonctionner sur les navigateurs basés sur Chromium et sur Firefox.
Si vous aviez besoin d’API très avancées, passer du mécanisme d’extension laxiste à Jetpack ou aux WebExtensions n’était pas toujours possible, mais pour la plupart des extensions la transition était simple — dans mon expérience personnelle, ça a même été agréable.
Firefox a introduit les WebExtensions à temps pour Firefox Quantum parce que c’était le moment où le modèle laxiste d’extensions allait de toute manière arrêter de fonctionner.
À ce stade, nous avons terminé avec le rappel historique. J’espère que vous êtes prêts pour un peu plus de technique, parce que c’est ainsi que je vais vous expliquer exactement quels problèmes ont été résolus lorsque nous sommes passés du modèle laxiste d’extensions aux WebExtensions.
Parlons d’XPCOM !
Comment ça a commencé
XPCOM, Cross-Platform Component Object Model, est peut‑être la fonctionnalité de Firefox qui peut être mieux décrite comme le noyau (pour ceux qui connaissent Gecko en profondeur, je considère XPConnect et le Cycle Collector comme des parties de XPCOM), aux côtés de SpiderMonkey, notre machine virtuelle JavaScript.
XPCOM est une technologie qui permet d’écrire du code en deux langages pouvant s’appeler mutuellement. Le code de Firefox est plein de C++ appelant du JavaScript, de JavaScript appelant du C++ et il y a longtemps, nous avons eu des projets qui ont ajouté Python et .Net dans le mélange. Ce mécanisme est extrêmement compliqué, car les langages ne partagent pas les mêmes définitions (qu’est-ce qu’un entier 64 bits en JavaScript ? Qu’est-ce qu’une exception JavaScript en C++ ?) ou le même modèle mémoire (comment gérer un objet JavaScript contenant une référence sur un objet C++ que C++ pourrait vouloir supprimer de la mémoire ?) ou le même modèle de concurrence (les workers JavaScript ne partagent rien, alors que les fils d’exécution C++ partagent tout).
Gecko lui-même a été conçu à l’origine comme des milliers de composants XPCOM pouvant chacun être implémenté en C++ ou en JavaScript, testé individuellement, branché, débranché ou remplacé dynamiquement et cela fonctionnait. De plus, l’architecture XPCOM permettait une programmation C++ beaucoup plus propre que celle disponible à l’époque, fonctionnait sur des dizaines de plates-formes et permettait de combiner le confort de pouvoir écrire du code en JavaScript et la vitesse brute permise par le C++.
Pour écrire un composant XPCOM, il faut généralement définir une interface, puis écrire l’implémentation en C++ ou JavaScript (ou en Rust, de nos jours, et peut-être bientôt en WebAssembly). Il faut encore ajouter à cela un peu de code d’intégration, mais bon, ça marche.
Lorsque les premiers développeurs de Firefox ont décidé d’ouvrir la plate-forme aux extensions, XPCOM a immédiatement été choisi comme technologie de base pour les modules complémentaires. Firefox avait juste à laisser les auteurs de modules complémentaires se brancher n’importe où dans le code et ils auraient un pouvoir extraordinaire à leur disposition.
Et les développeurs de modules complémentaires (dont je fais partie) l’ont certainement fait et se sont beaucoup amusés avec !
… l’ère du XPCOM immuable
Malheureusement, les problèmes ont commencé à s’accumuler progressivement.
Lorsque vous développez une grosse application, vous avez besoin de changer les choses, soit pour corriger des bogues ou ajouter de nouvelles fonctionnalités, soit pour améliorer les performances. Dans le monde XPCOM, cela signifie changer les composants XPCOM. Parfois pour ajouter de nouvelles fonctionnalités à un composant. Parfois pour en supprimer entièrement un parce qu’une meilleure conception le rendait inutile.
Durant la première ère des extensions XPCOM, tout ceci était généralement interdit. Si un composant XPCOM était utilisé par des extensions, les développeurs de Firefox n’avaient pas le droit de le modifier de manière incompatible. Ce système fonctionnait très bien pour les développeurs d’extensions mais est rapidement devenu un cauchemar pour les développeurs de Firefox — comme chaque changement devait être fait en maintenant la compatibilité à la fois externe (pour les développeurs Web) et interne (pour les développeurs d’extensions). Par conséquent, chaque composant XPCOM nsITruc
se retrouva rapidement accompagné par un nsITruc2
, qui représentait le meilleur composant — et chacun des deux composants devait bien entendu rester compatible avec l’autre, ce qui doublait la quantité de travail. Un cas était même encore plus compliqué pour les développeurs Firefox : une extension XPCOM pouvait remplacer n’importe quel composant XPCOM. Est-il nécessaire de mentionner qu’un tel remplacement constituait une très bonne manière de casser Firefox d’une manière incompréhensible pour les enquêteurs qui travaillaient sur les plantages ?
Cela signifiait que le développement est devenu de plus en plus lent, car nous devions vérifier chaque nouvelle fonctionnalité ou chaque amélioration par rapport non seulement aux fonctionnalités actuelles, mais aussi aux fonctionnalités passées/obsolètes ou simplement aux anciennes méthodes de travail qui étaient obsolètes depuis des années. Pendant un certain temps, cette taxe de développement était acceptable. Après tout, le principal concurrent de Firefox était Internet Explorer, qui présentait des problèmes architecturaux encore plus graves, et un nombre apparemment illimité de contributeurs de logiciels libres apportaient leur aide. En outre, l’ensemble des fonctionnalités du Web était beaucoup plus réduit, donc c’était toujours possible.
… l’ère des développeurs d’extensions sur tous les chemins critiques
Cependant, à mesure que le Web se développait, il est devenu évident que ces choix rendaient tout simplement impossible la résolution de certains problèmes, en particulier les problèmes de performance. Par exemple, vers 2008, les développeurs de Firefox ont réalisé que la plate‑forme comportait tout simplement trop de composants XPCOM et que cela nuisait considérablement aux performances, car les composants XPCOM empêchaient à la fois le compilateur à la volée (JIT) et C++ d’optimiser le code et nécessitaient trop de conversions de données. C’est ainsi qu’a commencé la « déCOMtamination », qui consistait à réécrire les sections du code dont les performances étaient critiques sans les composants XPCOM. Ce qui signifiait qu’il fallait casser des modules complémentaires.
Durant cette deuxième ère des extensions XPCOM, les développeurs de Firefox avaient l’autorisation d’enlever ou de modifier les composants XPCOM, à condition d’avoir d’abord contacté les développeurs d’extensions et d’avoir trouvé avec eux une méthode qui allait permettre de réparer leurs extensions. Ce changement de méthode permit de débloquer le développement mais, l’un dans l’autre, la taxe de développement avait encore augmenté. En effet, chaque changement de Firefox, même trivial, pouvait être bloqué pendant des semaines, le temps de concevoir des solutions de secours avec les développeurs d’extensions. C’est ainsi que les développeurs d’extensions se retrouvèrent à devoir payer une taxe de maintenance, puisqu’ils devaient dorénavant réparer leurs extensions à chaque version de Firefox. Dans certains cas, les développeurs de Firefox et les développeurs d’extensions entretenaient de très bons rapports, avec même certains développeurs d’extensions qui se retrouvèrent à concevoir les API utilisées à l’intérieur de Firefox. Dans d’autres cas, les développeurs d’extensions se lassèrent de cette surcharge de travail et abandonnèrent leurs extensions, parfois pour l’écosystème Chrome naissant.
… l’ère de Snappy
À cette époque, Mozilla a commencé à s’intéresser sérieusement à Chrome. Chrome avait été conçu à partir de principes très différents de Firefox :
- à l’époque, Chrome ne se souciait pas de consommer trop de mémoire ou de ressources système ;
- Chrome utilisait de nombreux processus, ce qui améliorait immédiatement la sécurité et la réactivité du navigateur ;
- initialement, Chrome n’avait pas de mécanisme d’extension, ce qui permettait aux développeurs de Chrome de refactoriser tout ce qui était nécessaire, sans cette « taxe de développement » ;
- lorsque Chrome a introduit son mécanisme d’extension, il l’a fait avec une API appropriée, qui pouvait généralement être maintenue indépendamment des changements apportés en arrière‑plan ;
- de plus, bien que Chrome était initialement plus lent que Firefox dans presque tous les comparatifs, il s’appuyait sur de nombreuses astuces de conception qui donnaient l’impression que le produit était plus rapide — et les utilisateurs ont adoré cela.
Il était clair pour Mozilla depuis des années que Firefox devait passer à une conception multi‑processus. En fait, des démonstrations de Firefox multi‑processus circulaient déjà à l’époque où Chrome 1.0 a été dévoilé. Le projet s’appelait Electrolysis, ou e10s en abrégé. Nous y reviendrons.
À l’époque, Mozilla a décidé de mettre en pause e10s, dont nous savions qu’il utiliserait beaucoup plus de mémoire que ce qui était acceptable pour beaucoup de nos utilisateurs, et de se concentrer sur un nouveau projet appelé Snappy (note : j’étais l’un des développeurs du projet Snappy). Snappy consistait à utiliser les mêmes astuces de conception que Chrome pour donner la même impression de vitesse à Firefox, en espérant ne pas avoir à tout remanier.
La raison pour laquelle Firefox paraissait plus lent que Chrome est que nous faisions à peu près tout dans un seul fil d’exécution. Lorsque Firefox écrivait un fichier sur le disque, cela bloquait les rafraîchissements visuels, ce qui faisait chuter le nombre d’images par seconde. Lorsque Firefox collectait la liste des onglets pour les sauvegarder en cas de plantage, cela bloquait les rafraîchissements, avec le même résultat. Lorsque Firefox nettoyait les cookies, cela bloquait les rafraîchissements, etc.
Il y avait deux solutions à cela, que nous avons toutes deux utilisées :
- chaque fois que cela a été possible, au lieu d’exécuter le code sur le fil d’exécution principal, nous l’avons déplacé vers un autre fil ;
- chaque fois que cela était impossible, nous devions diviser le traitement en petits morceaux dont nous pouvions garantir l’exécution en quelques millisecondes, puis intercaler manuellement ces morceaux dans le reste de l’exécution du fil d’exécution principal.
Ces deux solutions nous permettaient de nous assurer que nous n’introduisions pas de saccades et que nous pouvions répondre immédiatement lorsque l’utilisateur cliquait. Cela signifiait que l’interface utilisateur était réactive. La première technique avait l’avantage de bénéficier de l’aide du système d’exploitation, tandis que la seconde nécessitait un nombre considérable de mesures et de réglages. Les deux solutions étaient difficiles à mettre en œuvre, car nous étions soudainement confrontés à des problèmes de concurrence, qui sont notoirement difficiles à déboguer. Les deux solutions ont également été difficiles pour les développeurs d’extensions, car elles nécessitent de changer des fonctionnalités entières de synchrone à asynchrone, ce qui signifie souvent que l’extension devait être réécrite à partir de zéro.
Pour moi, c’est le temps des souvenirs, car c’est à ce moment qu’Irakli, Paolo et moi‑même (est‑ce que j’oublie quelqu’un ?) avons introduit Promise et ce qui est maintenant connu comme les fonction async
dans le code source de Firefox. Ces expériences (qui n’étaient en aucun cas les seules expériences autour du sujet) ont servi de champ d’expérimentation pour introduire ultérieurement ces fonctionnalités sur le Web. De manière plus immédiate, elles ont rendu l’écriture de code asynchrone beaucoup plus facile, tant pour les développeurs de Firefox que pour les développeurs d’extensions. Malgré ces améliorations (et d’autres qui n’ont pas tout à fait été approuvées comme standard), l’écriture et le débogage de code asynchrone restaient très compliqués.
Donc, une fois de plus, il y a eu une taxe de maintenance pour les développeurs de modules complémentaires, qui est rapidement devenue très compliquée. En termes de puissance d’extension, la situation était encore pire lorsque nous avons retiré du code du fil d’exécution principal, car ils étaient généralement déplacés vers des fils d’exécution C++, qui sont entièrement séparés de ceux de JavaScript. Les composants XPCOM disparaissaient ici et là, perdant leur puissance d’extension pour les développeurs de modules complémentaires.
Je crois que c’est à ce stade que de nombreux développeurs de modules complémentaires ont commencé à se plaindre sérieusement de cette taxe de maintenance — ou plus souvent ont simplement cessé de mettre à jour leurs modules complémentaires. Et ils avaient raison. En tant que développeur de modules complémentaires, j’avais depuis longtemps renoncé à la maintenance des miens, cela prenait trop de temps. La taxe de maintenance épuisait notre communauté de développeurs de modules complémentaires.
Et Mozilla a pris au sérieux la recherche d’une nouvelle façon d’écrire des modules complémentaires qui réduirait considérablement la taxe, à la fois pour les développeurs de Firefox et pour les développeurs de modules complémentaires. À l’époque, la solution était Jetpack et c’était plutôt génial ! Pendant un certain temps, deux mécanismes d’extension ont coexisté : Jetpack, plus propre, et le modèle laxiste, plus ancien.
… l’ère d’Electrolysis/Quantum
Snappy nous a mené assez loin, mais il n’a jamais pu résoudre tous les problèmes de Firefox.
Comme mentionné ci‑dessus, les développeurs de Firefox savaient depuis longtemps que nous aurions finalement besoin de passer à un modèle multi‑processus. C’était mieux pour la sûreté et la sécurité, cela permettait de s’assurer que les images seraient rafraîchies de façon fluide et cela semblait naturel. À ce moment‑là, les développeurs de Mozilla expérimentaient depuis un certain temps le multi‑processus sous Firefox, mais deux choses avaient empêché Mozilla d’aller de l’avant avec le multi‑processus sous Firefox (alias Electrolysis ou e10s) :
- le fait que plusieurs processus nécessitent une quantité considérable de mémoire vive ;
- le fait qu’avoir plusieurs processus nécessitait de réécrire à peu près tous les modules complémentaires — et que certains d’entre eux ne pourraient jamais être portés.
Au fur et à mesure que la mémoire vive devenait moins chère et que nous optimisions l’utilisation de la mémoire (projet MemShrink), le premier problème a progressivement cessé d’être bloquant. Le deuxième problème, en revanche, n’a pas pu être résolu.
Considérons le cas simple d’un module complémentaire qui doit d’une manière ou d’une autre interagir avec le contenu d’une page. Par exemple, un module complémentaire conçu pour augmenter le contraste. Avant e10s, il s’agissait d’un code JavaScript qui existait dans la fenêtre principale de Firefox et qui pouvait manipuler directement le DOM des pages individuelles. C’était assez simple à écrire. Avec e10s, ce module complémentaire devait être réécrit pour fonctionner sur plusieurs processus. Le processus parent ne pouvait communiquer avec les processus enfants qu’en échangeant des messages et les processus enfants pouvaient être arrêtés à tout moment, y compris pendant le traitement d’un message, soit par le système d’exploitation (en cas de plantage), soit par l’utilisateur final (en fermant un onglet). Ce module complémentaire pourrait être porté sur e10s parce que les processus qui traitaient le contenu des pages Web exécutaient également JavaScript, et parce que l’équipe e10s avait exposé des API permettant aux modules complémentaires d’envoyer et de recevoir des messages et de se charger dans ces processus de contenu.
Cependant, tous les processus ne pouvaient pas fonctionner aussi bien avec les modules complémentaires. Par exemple, les processus dédiés à la protection de Firefox contre les plantages notoires du greffon Flash ne disposaient pas de machine virtuelle JavaScript. Les processus dédiés à l’interaction avec le processeur graphique n’avaient pas de machine virtuelle JavaScript. Tout cela pour de (bonnes) raisons de performance et de sécurité — et le fait d’ajouter une machine virtuelle JavaScript à ces processus les aurait rendus beaucoup plus complexes.
Et pourtant, Mozilla n’a pas eu le choix. Chaque jour où Mozilla n’a pas livré Electrolysis était un jour où Chrome était tout simplement meilleur en termes d’architecture, de sûreté et de sécurité. Malheureusement, Mozilla a retardé Electrolysis de plusieurs années, en partie à cause de l’illusion que les évaluations de Firefox étaient assez bonnes pour que cela n’ait pas d’importance sur le long terme, en partie parce que nous avons décidé de tester Electrolysis avec FirefoxOS avant Firefox lui‑même, mais surtout parce que nous ne voulions pas perdre tous ces modules complémentaires.
Lorsque Mozilla s’est finalement engagé dans la transition vers Electrolysis, certains développeurs ont porté leurs modules complémentaires — consacrant un temps considérable à cette tâche — mais beaucoup ne l’ont pas fait, soit parce que c’était impossible pour leur module complémentaire, soit, plus souvent, parce que nous les avions perdus à cause de la taxe de maintenance des modules complémentaires. Et malheureusement, même les modules complémentaires qui avaient été portés sur Electrolysis se sont mis à ne plus fonctionner, un par un, pour toutes les autres raisons mentionnées dans cet article.
Finalement, Mozilla a décidé d’introduire les WebExtensions et de faire enfin le saut vers e10s dans le cadre du projet Quantum. Nous avions perdu des années de développement que nous ne récupérerions jamais.
Les performances s’amélioraient. Les modules complémentaires devaient être réécrits. La puissance des modules complémentaires avait irrémédiablement diminué. Le mécanisme d’extension basé sur XPCOM a été en grande partie abandonné (nous l’utilisons toujours en interne).
… le futur est Rust, Wasm, Fission…
Nous vivons aujourd’hui dans une ère post‑Quantum. Chaque fois que cela est possible, de nouvelles fonctionnalités sont implémentées en Rust. Je ne me souviens pas si nous avons déjà livré des fonctionnalités implémentées en Wasm, mais cela fait partie de la feuille de route.
De base, Rust ne fonctionne pas bien avec XPCOM. Rust a un mécanisme différent pour interagir avec d’autres langages, qui fonctionne très bien, mais il ne discute pas avec XPCOM nativement. Écrire ou utiliser du code XPCOM dans Rust est possible et atteint progressivement le stade où il fonctionne sans trop d’efforts, mais pour la plus grande partie de l’existence du code Rust dans Firefox, c’était simplement trop compliqué à faire. Par conséquent, même si nous avions laissé le mécanisme d’extension basé sur XPCOM disponible, la plupart des fonctionnalités implémentées en Rust n’auraient tout simplement pas été accessibles aux modules complémentaires, à moins que nous n’ayons explicitement publié une API pour eux — éventuellement sous la forme d’une API WebExtension.
Bien que je n’aie pas été étroitement impliqué dans Wasm‑in‑Gecko, je pense que l’histoire se déroulera de la même manière. Pas de XPCOM au début. Plus tard, progressivement, une sorte de prise en charge de XPCOM, mais seulement sur décision explicite de le faire. Peut‑être exposé comme une API d’extension Web, plus tard.
De plus, après le projet Electrolysis vient le projet Fission. Il s’agit d’une autre refactorisation majeure de Firefox qui va beaucoup plus loin dans la direction prise initialement par Electrolysis en divisant davantage Firefox en processus pour renforcer la sécurité, la sûreté et, espérons‑le, les performances ultérieures. Bien que cela n’affecte pas directement XPCOM, cela signifie que tout module complémentaire utilisant le mécanisme basé sur XPCOM qui a été porté sur le projet Electrolysis devra être entièrement réécrit une fois de plus.
Toutes ces raisons confirment que le choix de se débarrasser des modules complémentaires basés sur XPCOM aurait pu, au mieux, être ajusté pour prolonger l’agonie de la technologie, mais que l’issue était courue d’avance.
Les problèmes avec XUL
Mais attendez, ce n’est pas tout ! Jusqu’à présent, nous n’avons mentionné que XPCOM, mais XPCOM ne représentait que la moitié de la technologie des modules complémentaires de Firefox.
Comment cela a commencé
XUL, le XML User interface Language, a été comme l’une des révolutions initiées par Firefox. Pour la première fois, un langage déclaratif pour les interfaces utilisateurs fonctionnait. Imaginez placer des boutons, appliquer un style avec des CSS, les connecter avec un peu de JavaScript, ajouter un peu de métadonnées pour atteindre l’accessibilité, la localisation, les préférences de stockage… En plus un excellent mécanisme appelé XUL overlays qui permet de brancher facilement des composants dans des interfaces existantes, par exemple pour étendre un menu ou ajouter un nouveau bouton, etc., sans avoir à changer l’autre document.
Pendant la plus grande partie de l’existence de Mozilla, c’est ainsi que l’interface utilisateur de Firefox a été écrite — et bien sûr l’interface utilisateur des modules complémentaires a été écrite. Et cela fonctionnait extrêmement bien. En tant que développeur de modules complémentaires qui en avait assez d’écrire des interfaces utilisateur en GTK, Win32 et Swing, pour la première fois, j’ai pu développer une expérience utilisateur qui était bien meilleure que tout ce que j’avais pu réaliser avec ces boîtes à outils ; de plus, cela ne m’a pris que quelques secondes au lieu de plusieurs heures, je pouvais simplement recharger pour voir à quoi cela ressemblait au lieu d’avoir besoin de reconstruire l’application et, contrairement à GTK et Win32, je n’avais pas à craindre de plantages, car mon code était écrit dans un langage sans danger pour la mémoire.
Si vous pensez que cela ressemble beaucoup à HTML5 (et peut‑être Electron) avec les bonnes bibliothèques et les bon cadriciels, vous avez tout à fait raison. XUL a été développé à l’époque du HTML4, lorsque les spécifications du Web étaient coincées dans les limbes, et a été conçu en grande partie comme le successeur du HTML dédié aux applications plutôt qu’aux documents. Il y a presque vingt ans, Mozilla a publié une première version de XULRunner, qui était essentiellement une version antérieure d’Electron utilisant XUL au lieu de HTML (HTML pouvait également être inséré dans XUL).
… quelques problèmes de XUL
Si vous écriviez des modules complémentaires basés sur XUL, vous vous êtes vite rendu compte qu’il était… compliqué de l’empêcher de casser des choses. Plusieurs modules complémentaires pouvaient modifier la même partie de l’interface utilisateur, entraînant des résultats étranges. Plusieurs modules complémentaires pouvaient accidentellement injecter des fonctions JavaScript avec le même nom, ou avec le même nom qu’une fonction existante, provoquant toutes sortes de dommages.
De même, il était très simple d’écrire une extension malveillante. Vous pouviez facilement enregistrer toutes les touches pressées par l’utilisateur, en récupérant tous ses mots de passe, mais pourquoi vous donner la peine de le faire alors que vous pouviez simplement appliquer un correctif au gestionnaire de mots de passe pour envoyer toutes les informations à un site Web distant ? Et, pour être clair, ce n’est pas de la science‐fiction. Bien que je ne connaisse aucune extension qui soit allée aussi loin, je connais des installateurs de produits sans rapport avec le sujet (au moins deux d’entre eux sont des leaders du marché dont le nom ne sera pas mentionné dans ce billet) qui ont installé silencieusement des modules complémentaires invisibles de Firefox qui ont pris le contrôle de fonctionnalités clés et ont compromis la vie privée des utilisateurs.
Des propositions avaient été faites pour améliorer la sécurité, mais il était très clair que, tant que nous conserverions XUL (et XPCOM), nous ne pouvions rien faire pour empêcher un module complémentaire malveillant de faire tout ce qu’il voulait.
… l’ère du HTML5
Une fois le travail sur HTML5 commencé, Mozilla a apporté avec enthousiasme les fonctionnalités de XUL. Progressivement, HTML5 a obtenu le stockage, le contenu éditable, le glisser‐déposer, les composants (qui étaient connus sous le nom de XBL dans XUL), la manipulation de l’historique, l’audio, la cryptographie, etc., ainsi qu’un support suffisant pour permettre aux bibliothèques clientes de mettre en œuvre l’accessibilité et l’internationalisation.
Bien que HTML5 ne dispose toujours pas de toutes les fonctionnalités de XUL, il a finalement atteint un stade où de nombreuses fonctionnalités qui avaient été implémentées dans Gecko pour prendre en charge XUL devaient également être implémentées dans Gecko pour la gestion du HTML5. Comme c’était le cas avec XPCOM, cela s’est traduit par une taxe de développement, car chaque nouvelle fonctionnalité de HTML5 devait être implémentée de manière à ne casser aucune des fonctionnalités de XUL, même si les développeurs de modules complémentaires essayaient d’une manière ou d’une autre de les combiner.
Cela a considérablement ralenti le développement de Gecko et a augmenté le nombre de bogues qui ont accidentellement tué les modules complémentaires basés sur XUL, augmentant ainsi la taxe de maintenance des développeurs de modules complémentaires.
À ce moment‑là, Mozilla avait depuis longtemps décidé d’arrêter d’améliorer XUL et de se concentrer plutôt sur HTML5. Comme les performances de HTML5 devenaient meilleures que celles de XUL pour de nombreuses tâches, les développeurs de Firefox ont commencé à porter des composants de XUL vers HTML5. Le résultat était plus agréable (parce que le design était nouveau), plus rapide (parce que Gecko était optimisé pour HTML5) et créer des modules complémentaires basés sur XUL devenait plus compliqué. De plus, il est devenu plus facile d’engager et de former les développeurs sur l’interface de Firefox car, soudainement, ils pouvaient utiliser leurs connaissances en HTML5 et leurs cadriciels HTML5 dans Firefox.
C’est à peu près à ce moment que le Jetpack est entré en scène pour la première fois. Jetpack a permis aux auteurs de modules complémentaires d’écrire leurs extensions avec HTML5 au lieu de XUL. C’était mieux pour la plupart des auteurs de modules complémentaires expérimentés et outillés en HTML5. Bien sûr, comme il manquait à HTML5 certaines fonctionnalités de XUL, cela ne fonctionnait pas pour tout le monde.
… la poussée vers Servo
En parallèle, les travaux avaient commencé chez Mozilla sur le moteur de restitution Servo. Bien que le moteur ne soit pas complet (et ne l’est toujours pas à ce jour), des démonstrations extrêmement intéressantes ont montré comment Servo (ou au moins des morceaux de Servo) pourrait un jour remplacer Gecko (ou au moins des morceaux de Gecko) par un code à la fois plus facile à lire et à modifier, plus sûr et beaucoup plus rapide.
Il y avait un hic, bien sûr : l’équipe Servo n’avait pas les ressources pour réimplémenter également XUL, d’autant plus que Mozilla avait décidé depuis longtemps d’arrêter de travailler sur cette technologie. Afin de pouvoir remplacer Gecko (ou des parties de celui‑ci) par Servo, Mozilla devait d’abord migrer l’interface utilisateur de Firefox vers HTML5.
Dans Firefox, cela a permis de poursuivre le cercle vertueux : en diminuant la quantité de XUL, on a pu simplifier Gecko, ce qui a réduit la taxe de développement de Gecko et a permis aux développeurs de Gecko d’améliorer la vitesse de tout HTML5. Cela signifiait également que l’interface utilisateur et les développeurs de modules complémentaires pouvaient utiliser des technologies mieux optimisées et les bibliothèques et cadriciels Web existants.
Là encore, cela signifiait que l’utilisation de XUL pour les interfaces utilisateur avait de moins en moins de sens et que cela réduisait le nombre de choses que les modules complémentaires basés sur XUL pouvaient espérer réaliser.
… l’ère d’Electrolysis/Quantum/Fission
Et puis vint le projet Quantum. Comme nous l’avons vu plus haut, chaque jour que Mozilla passait sans livrer Electrolysis était un jour que Firefox passait à être pire que Chrome en termes de sécurité et de plantages.
Lorsque XUL a été conçu, l’exécution parallélisée en multiples fils d’exécution (multithreading) était encore considérée comme un sujet de recherche, GNU/Linux et System 7 (l’ancêtre de macOS) n’avaient même pas de multithreading approprié, et peu de personnes en dehors du monde universitaire considéraient sérieusement que toute application destinée aux utilisateurs aurait besoin d’une quelconque concurrence. XUL a donc été conçu pour un seul processus et un seul fil d’exécution.
Lorsque le moment est venu d’implémenter Electrolysis pour Firefox, de nombreuses fonctionnalités de XUL se sont révélées inutilisables. Peut‑être qu’une nouvelle version de XUL aurait pu être conçue pour mieux gérer ce paradigme multi‑processus, mais cela aurait augmenté une fois de plus la taxe de développement sans diminuer la tâche de maintenance des développeurs de modules complémentaires qui auraient eu besoin, malgré tout, de porter leurs modules sur un nouveau XUL. Le choix a donc été fait de réécrire en HTML5 les fonctionnalités qui avaient besoin d’être réécrites pendant la période de lancement d’Electrolysis.
Après le projet Electrolysis vient le projet Fission. Si l’on considère la façon dont nous devons refactoriser le code de Firefox pour Fission, il semble très probable que le projet Fission aurait nécessité un XUL3 ou aurait, au minimum, encore une fois cassé tous les modules complémentaires.
Bien que XUL n’aurait pas été entièrement supprimé de Firefox ou de Gecko avant plusieurs années, l’ère de XUL était officiellement terminée. Encore une fois, le choix de prolonger le mécanisme d’extension basé sur XUL aurait pu être modifié pour prolonger l’agonie, mais la fin était attendue depuis longtemps.
Et maintenant ?
Eh bien, pour les développeurs de modules complémentaires Firefox, le présent et l’avenir prévisible s’appellent WebExtensions.
De par leur conception, les WebExtensions sont plus limitées que le mécanisme d’extension laxiste. De par leur conception, cela fonctionne également mieux. La majeure partie de la taxe de développement de Firefox a disparu, car seule l’API WebExtensions a besoin d’être protégée, et non l’ensemble du code de Firefox. La majeure partie de la taxe de maintenance a disparu, car l’API WebExtensions est stable (il y a malheureusement eu quelques exceptions). Elle est également beaucoup plus simple à utiliser, permettant aux développeurs de modules complémentaires de partager du code entre les modules complémentaires de Firefox et Chromium, et devrait à terme faciliter l’écriture d’extensions fonctionnant parfaitement sur les ordinateurs de bureau et mobiles.
Le principal inconvénient est, bien sûr, que les WebExtensions ne donnent pas aux développeurs de modules complémentaires autant de pouvoir que le mécanisme d’extension laxiste. J’espère que toute la puissance dont les développeurs de modules complémentaires ont besoin pourra à terme être ajoutée à l’API des WebExtensions, mais c’est quelque chose qui demande une force d’ingénierie, une ressource précieuse qui nous fait cruellement défaut.
Bien que je réalise que toutes les actions décrites ci‑dessus ont eu un coût pour les développeurs et les utilisateurs de modules complémentaires, j’espère vous avoir convaincus que ces choix faits par Mozilla étaient nécessaires pour préserver Firefox et le maintenir dans la course contre Chrome.
# Merci !
Posté par Salamandar . Évalué à 10.
Merci pour cet excellent billet !
Petit point cependant : j'aurais bien aimé avoir quelques dates pour avoir des points de repère chronologique.
[^] # Re: Merci !
Posté par stopspam . Évalué à 4.
Je plussois, excellente dépêche !!
# L'évolution...
Posté par tikilou (site web personnel) . Évalué à 2.
…Est parfois douloureuse, mais vous avez fait ce que vous aviez à faire.
[^] # Re: L'évolution...
Posté par L'intendant zonard (site web personnel) . Évalué à 3.
En tant qu'utilisateur lambda de Firefox, fidèle de toujours, sous Mageia Linux (à la maison) et en me jetant par les Fenêtres (au boulot), je suis impressionné de prendre la mesure des formidables mouvements tectoniques derrière l'interface que j'ai vu évoluer sans heurt. Un bravo venant s'ajouter aux remerciements…
Intendant, donc méchant, mais libre !
# Benchmark
Posté par barmic 🦦 . Évalué à 10.
Je trouve ça très intéressant. C'est un super exemple pour montrer comment se concentrer sur des benchmarks sans les remettre en cause et sans prendre le temps de remettre l'utilisateur au centre peut mener à des problèmes.
https://linuxfr.org/users/barmic/journaux/y-en-a-marre-de-ce-gros-troll
# Plus de Firefox pour moi
Posté par Dafyd . Évalué à -2.
Bonjour,
En fait, et surement pour de bonnes raisons, tout ce qui faisait la force de Firefox par le passé vis a vis de Chrome a été supprimé pour se rapprocher de Chrome. Donc on se retrouve maintenant avec un Chrome-like, en moins bien (et ça me fait mal de le dire).
Du coup perso je suis parti…
[^] # Re: Plus de Firefox pour moi
Posté par eric1803 . Évalué à 1.
Je constate quand même que Firefox continue à perdre des parts de marché et que en plus la plupart des développeur d'extension ont fini par jeter l'éponge.
Plus de thème sympas (quelqu'un se souvient de Noia sniff), d'extension pour combler des lacunes (font changer pour les menus et le reste en un click), …
Et en plus ca s'applique non seulement a Firefox mais aussi à thunderbird et là c'est encore pire vu que les développeurs ont été encore moins nombreux. Plus de connection a un serveur exchange pour le calendrier, thème idem, même enigmail a pris du temps à être porté.
Pour moi ca ressemble au chant du cygne
[^] # Re: Plus de Firefox pour moi
Posté par barmic 🦦 . Évalué à 10.
Si tu indiquait un élément concret, ça pourrait peut être amener une discussion.
https://linuxfr.org/users/barmic/journaux/y-en-a-marre-de-ce-gros-troll
[^] # Re: Plus de Firefox pour moi
Posté par Bruno Ethvignot (site web personnel) . Évalué à 10.
Quand Chrome est arrivé en 2008, Firefox avait tout de même bien préparé le terrain. En arrivant Chrome s'est également inspiré des navigateurs existants et de Firefox. Jusqu'à preuve du contraire même si Chrome a proposé de bonnes idées, Chrome n'a pas tout inventé et certaines fonctionnalités comme la disparition du « http:// » de la barre d'adresse et peut-être bientôt de la barre d'adresses entière ne sont pas spécialement fantastiques.
En 2020 Firefox reste un très bon choix vis à vis de Chrome, ne serait-ce que pour le respect de la vie privée. Personnellement je ne vois pas en quoi Chrome est meilleur que Firefox. L'important c'est d'avoir le choix, mais effectivement le choix est surtout monopolisé par Chrome est ses dérivés (Brave, Opera, Vivaldi, Edge…).
Utiliser Firefox est aussi une manière de donner moins de poids à une société comme Google dans le contrôle le développement de Chromium (qui malheureusement est utilisé par presque 80 % des utilisateurs), donc dans le contrôle du web.
[^] # Re: Plus de Firefox pour moi
Posté par Zenitram (site web personnel) . Évalué à 10.
Le problème est que ça devient de plus en plus le seul argument pour Firefox : être contre Chrome. Et de plus en plus de monde, même ici dans les commentaires, admettent qu'il n'y a pas d'autre raison pour eux.
Et franchement, ça mériterait bien plus que cet anti-Google vu le bijou que c'était à une époque, en avance, alors que la il ne fait que suivre avec retard Chrome sans propose un rêve (respect des dév… Ho zut, contrat avec Google, sic au passage pour de l'anti-Google, reconduit mais on vire quand même 25% du monde), une autre expérience :(.
Il y a bien un peu de respect de la vie privée en plus que Chrome, mais c'est peu (et perso j'ai encore le souvenir du site de Mozilla qui file par défaut, sans bloqueur tiers car Mozilla ne voulait surtout pas bloquer par défaut, mes données de navigation de leur site à Google via Analytics, sans excuse de Mozilla à ce sujet "oui on a bien merdé sur vos données", désolé ça ne donne pas bien confiance sur leur pub de bien protéger ma vie privée)
Bref, Mozilla ne pourra pas longtemps tenir avec l'argument faire relativement pareil que Chrome mais pas de Google.
[^] # Re: Plus de Firefox pour moi
Posté par barmic 🦦 . Évalué à 3.
Je trouve que c'est aller un peu vite. Personnellement mes onglets sont verticaux (grâce à tabcenter-redux que je préfère à Tree Style Tab) c'est impossible avec chrome par exemple. Je ne sais pas par contre ce qui fait utiliser Chrome pour un utilisateur éclairé (c'est à dire qui a connaissance des 2, qui sait les installer,…). Je crois avoir entendu dire que les outils de dev étaient un peu mieux, mais je suis pas sûr que ce ne soit pas un problème d'habitude par exemple.
https://linuxfr.org/users/barmic/journaux/y-en-a-marre-de-ce-gros-troll
[^] # Re: Plus de Firefox pour moi
Posté par Zenitram (site web personnel) . Évalué à 6.
C'est impossible, oui, et c'est une des choses qui me font rester, voire la seule. C'est gênant que ce soit la seule quand même…
(et surtout, depuis Quantum, ça passe par un hack, on se tape les onglets quand même en haut car impossible à enlever par l'extension, il faut un hack CSS qui ne peut s'enlever automatiquement si on n'a plus le panneau visible, donc expérience utilisateur bof, pas la priorité de Mozilla d'être différent)
Plus (mini subjectivement, voir autres commentaires) rapide à un moment, moins de pb de compatibilité (et de la faute de Mozilla hein, exemple), faire comme les potes et comme on a pas grand chose de nos jours pour dire que Firefox est mieux et qu'on n'est pas anti-Google que Mozilla met quand même en avant, toutes les erreurs de com' de Mozilla qui ont fait qu'on veut "punir" en quittant et que Google est certes pas mieux mais eux n'ont pas un manifeste disant qu'ils sont plus mieux bien, et j'en passe.
La question devrait plutôt être : pourquoi ne pas prendre le leader? C'est le bonus du leader, un classique, le challenger doit avoir mieux à proposer pour que les gens ne préfèrent pas la sécurité du leader. C'est ce que Mozilla savait faire il y a 15 ans, plus maintenant.
[^] # Re: Plus de Firefox pour moi
Posté par barmic 🦦 . Évalué à 3.
Bof quand tu parle des avantages pour Chrome c'est encore plus petit (une peut-être sensation que ça va un peu plus vite).
Alors ne me considérant pas utilisateur lambda je vais me garder de parler pour eux. Mais en ce qui me concerne ça me permet à la fois de supprimer cette barre, mais aussi d'autres parties et d'en redimensionner certaines. Je m'en servais bien avant Quantum. Donc je suis plutôt satisfait que ça existe. Je doute que l'utilisateur lambda s'intéresse au fait de mettre les onglets en vertical.
Un argument objectif clair et net d'un coté et de l'autre le seul argument intrinsèque à Firefox c'est "à une époque c'était subjectivement plus rapide" ? Ça n'est pas léger ?
Pour rappel même à la grande époque de firefox n'avais qu'un seul argument (et demi si on veut être gentil) : les onglets (le blocage de popup était possible sur IE, mais c'était pas une fonctionnalité de base. La barre de google par exemple le permettait).
On est surtout devant des logiciels qui sont arrivé à un point où il devient difficile d'innover. Que les développeurs aient une fibre libristes (comme Mozilla), qu'ils soient des armées à temps pleins (comme Google) ou qu'ils aient toujours fais de l'innovation leur marque de fabrique (comme Opera), il semble clair qu'on est arrivé à un plateau d'innovation. Ça n'est pas la faute de Mozilla. Tu peux leur reprocher de ne pas être irréprochable en terme de vie privée (à raison), mais ça ne changerais rien à l'affaire.
Regarde un exemple très simple. Zoom est un pur carnage en terme de vie privée, c'est probablement la pire solution possible, ils ont eux-même reconnu leurs problèmes. Ça ne les empêche pas d'avoir beaucoup mieux tirer leur épingle du jeu cette années que n'importe quelle autre solution de visoconf. Les gens pour qui l'UX est important comme tu le rappel ne choisissent pas du tout leurs logiciels en fonction de l'étique des développeurs. Être irréprochable n'est pas un argument pour eux.
https://linuxfr.org/users/barmic/journaux/y-en-a-marre-de-ce-gros-troll
[^] # Re: Plus de Firefox pour moi
Posté par BohwaZ (site web personnel, Mastodon) . Évalué à 5.
Il est toujours possible d'innover, il n'y a qu'à regarder Vivaldi !
Et Firefox pourrait aussi faire ce qu'il a toujours fait : piquer les bonnes idées aux autres. Problème, depuis plusieurs années ils ne piquent plus que les mauvaises idées (design de Chrome, suppression de l'URL, etc.)…
« Je vois bien à quels excès peut conduire une démocratie d'opinion débridée, je le vis tous les jours. » (Nicolas Sarkozy)
[^] # Re: Plus de Firefox pour moi
Posté par Bruno Ethvignot (site web personnel) . Évalué à 4.
Firefox a toujours a toujours été en compétition avec le navigateur dominant, Internet Explorer il y a quinze ans, Google Chrome aujourd'hui. De mon côté ce n'est pas le seul argument, Firefox fonctionne bien et fait le boulot. J'ai testé Google Chromium et Brave, je ne vois pas ce que m'apporterait de plus d'utiliser un de ces deux navigateurs.
Tu ne peux pas comparer le marché des navigateurs en 2004, où Microsoft avait abandonné le développement d'Internet Explorer et que Firefox n'avait pas vraiment de concurrents, au marché des navigateurs de 2020 où tous des développeurs de Google, Microsoft, Opera et autres contribuent activement au projet Chromium. Comme l'indique justement David Teller dans son billet la force d’ingénierie, est une ressource précieuse qui fait cruellement défaut à Mozilla.
Sérieusement Google Chrome propose un rêve ? Les Accelerated Mobile Pages ou les Web Bundles de Google ne me font pas rêver (voir l'article « WebBundles Harmful to Content Blocking, Security Tools, and the Open Web (Standards Updates #2) »).
Mozilla Firefox sera toujours meilleur en vie privée que Google Chrome ou Microsoft Edge. L'objectif de Google et Microsoft est d'aspirer le plus de données possible de leurs utilisateurs, en essayant de faire croire qu'ils respectent la vie privée de leurs utilisateurs.
Nous verrons, mais pour l'instant Mozilla Firefox est un navigateur web qui fait le job, donc je ne vois pas de raison d'en changer.
[^] # Re: Plus de Firefox pour moi
Posté par pulkomandy (site web personnel, Mastodon) . Évalué à 3.
Ça m'étonne toujours le silence sur Safari dans ces discussions (apparu en 2003, version Windows de 2007 à 2012). Pourtant il a aussi bien fait bouger les choses.
[^] # Re: Plus de Firefox pour moi
Posté par nlgranger . Évalué à 1. Dernière modification le 16 octobre 2020 à 15:31.
Le support de wayland meilleur, en particulier pour la mise à l'échelle avec un facteur qui n'est pas entier. Bon chrome ne devrait pas trop tarder à suivre mais c'est un exemple.
# XULRunner… snif…
Posté par Claude SIMON (site web personnel) . Évalué à 4.
C'est vrai que XUL complétait parfaitement HTML4 (ou plus exactement XHTML), lui apportant les composants graphiques permettant à l'utilisateur d'interagir efficacement avec l'application. On basculait facilement de l'un à l'autre avec les espaces de noms XML, et on pouvait utiliser les CSS sur du XUL.
XULRunner était quand même pas mal utilisé à l'époque. Je me rappelle notamment que l'application TomTom Home, une application Windows qui permettait de mettre à jour les GPS de la même marque, était basée sur XULRunner.
Moi-même je l'ai utilisé, quoique de manière atypique (utilisation de C++ à la place de JavaScript). Je m"étais même fendu d'un journal à l'époque : https://linuxfr.org/users/epeios/journaux/xulrunner-et-c (désolé, mais le blog n'existe plus).
J'étais bien embêté quand ils l'ont arrêté. Je me suis rabattu sur HTML5 dés que ce dernier a été standardisé, avec CEF pour commencer, puis avec Electron, mais toujours en C++ (on ne se refait pas…).
S'il refaisait l'équivalent de XULRunner avec le Firefox d'aujourd'hui, je pense que je laisserais tenter…
Zelbinium, pour explorer le numérique de façon ludique par la programmation de montages électroniques.
# Mozilla : des développeurs altruistes ?
Posté par Eiffel . Évalué à 5.
Je vous remercie pour cette dépêche très intéressante.
Le côté technique était bien expliqué.
Toutefois j'ai beaucoup aimé le fait de voir Firefox évolué de l'intérieur.
Cette vision apporte notamment une justification au fait que Firefox ait perdu des parts de marché face à Chrome.
En ne laissant jamais tomber les développeurs d'extensions, les développeurs de Mozilla avaient moins de temps pour développer le navigateur et il a donc été rattrapé et malheureusement dépassé par son concurrent.
Les détracteurs de Firefox devraient lire cette dépêche avant de dégainer leurs critiques.
# extensions vérifiées payantes ou avec pub...
Posté par tao popus . Évalué à 3.
Visiblement, Mozilla veux faire payer les créateurs d'extensions et peut etre à de la pub aus passage…
https://www.nextinpact.com/lebrief/44033/les-extensions-verifiees-arrivent-dans-firefox-programme-payant-ouvrant-voie-publicite
Suivre le flux des commentaires
Note : les commentaires appartiennent à celles et ceux qui les ont postés. Nous n’en sommes pas responsables.