Gecko (software)

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search
Gecko
Mozillagecko-logo.svg
Developer(s)Mozilla Foundation, Mozilla Corporation, Adobe Systems, and other contributors
Repository Edit this at Wikidata
Written inC++, JavaScript, Rust
TypeBrowser engine
LicenseMPL 2.0[1][2]
Websitedeveloper.mozilla.org/en-US/docs/Gecko

Gecko is a browser engine developed by Mozilla. It is used in the Firefox browser, the Thunderbird email client, and many other projects.

Gecko is designed to support open Internet standards, and is used by different applications to display web pages and, in some cases, an application's user interface itself (by rendering XUL). Gecko offers a rich programming API that makes it suitable for a wide variety of roles in Internet-enabled applications, such as web browsers, content presentation, and client/server.[3]

Gecko is written in C++ and JavaScript,[4][5] and, since 2016, additionally in Rust.[6][7] It is free and open-source software subject to the terms of the Mozilla Public License version 2.[8] Mozilla officially supports its use on Android,[4] Linux, macOS, and Windows.[9]

History[edit]

Development of the layout engine now known as Gecko began at Netscape in 1997, following the company's purchase of DigitalStyle. The existing Netscape rendering engine, originally written for Netscape Navigator 1.0 and upgraded through the years, was slow, did not comply well with W3C standards, had limited support for dynamic HTML and lacked features such as incremental reflow (when the layout engine rearranges elements on the screen as new data is downloaded and added to the page). The new layout engine was developed in parallel with the old, with the intention being to integrate it into Netscape Communicator when it was mature and stable. At least one more major revision of Netscape was expected to be released with the old layout engine before the switch.

After the launch of the Mozilla project in early 1998, the new layout engine code was released under an open-source license. Originally unveiled as Raptor, the name had to be changed to NGLayout (next generation layout) due to trademark problems. Netscape later rebranded NGLayout as Gecko. While Mozilla Organization (the forerunner of the Mozilla Foundation) initially continued to use the NGLayout name (Gecko was a Netscape trademark),[10] eventually the Gecko branding won out.

In October 1998, Netscape announced that its next browser would use Gecko (which was still called NGLayout at the time) rather than the old layout engine, requiring large parts of the application to be rewritten. While this decision was popular with web standards advocates, it was largely unpopular with Netscape developers, who were unhappy with the six months given for the rewrite.[11] It also meant that most of the work done for Netscape Communicator 5.0 (including development on the Mariner improvements to the old layout engine) had to be abandoned. Netscape 6, the first Netscape release to incorporate Gecko, was released in November 2000 (the name Netscape 5 was never used).

As Gecko development continued, other applications and embedders began to make use of it. America Online, by this time Netscape's parent company, eventually adopted it for use in CompuServe 7.0 and AOL for Mac OS X (these products had previously embedded Internet Explorer). However, with the exception of a few betas, Gecko was never used in the main Microsoft Windows AOL client.

On July 15, 2003, AOL laid off the remaining Gecko developers and the Mozilla Foundation (formed on the same day) became the main steward of Gecko development. Today, Gecko is developed by employees of the Mozilla Corporation, employees of companies that contribute to the Mozilla project, and volunteers.

In October 2016, Mozilla announced Quantum, an ongoing project encompassing several software development efforts to "build the next-generation web engine for Firefox users". It includes numerous improvements to Gecko, taken from the experimental Servo project.[12][13] Firefox 57, also known as "Firefox Quantum", first shipping in November 2017, is the initial version with major components from the Quantum/Servo projects enabled. These include increased performance in the CSS and GPU rendering components. Additional components will be merged from Servo to Gecko incrementally in future versions.[12]

In September 2018, Mozilla announced GeckoView, the foundation of Mozilla's next generation of mobile products based on a software library that makes Gecko reusable for Android, encompassing newer software development efforts to "decouple the engine itself from its user interface, and made it easy to embed in other applications". Firefox Focus 7.0, shipped in the same month[14], is the initial version introduced GeckoView, with increased performance in median page loading.[15][16] Firefox Reality was also built with GeckoView.[15] In June 2019, Mozilla announced Firefox Preview as an ongoing project that focuses on building Android web browser with GeckoView.[17]

Standards support[edit]

From the outset, Gecko was designed to support open Internet standards. Some of the standards Gecko supports include:

Gecko also partially supports SVG 1.1.[20] The SVG font, color profile, animation, view, and cursor modules are yet to be implemented and the filter and text modules are only partially implemented. The extensibility module is also implemented but is currently disabled.

In order to support web pages designed for legacy versions of Netscape and Internet Explorer, Gecko supports DOCTYPE switching. Documents with a modern DOCTYPE are rendered in standards compliance mode, which follows the W3C standards strictly. Documents that have no DOCTYPE or an older DOCTYPE are rendered in quirks mode, which emulates some of the non-standard oddities of Netscape Communicator 4.x; however, some of the 4.x features (such as layers) are not supported.

Gecko also has limited support for some non-standard Internet Explorer features, such as the marquee element and the document.all property (though pages explicitly testing for document.all will be told it is not supported).[21]

Usage[edit]

Gecko is primarily used in web browsers, the earliest being Netscape 6 and Mozilla Suite (later renamed SeaMonkey). It is also used in other Mozilla web browser derivatives such as Firefox and Firefox for mobile and the implementation of the Internet Explorer-clone that is part of Wine.[22] Mozilla also uses it in their Thunderbird email-client.

Other web browsers using Gecko include GNU IceCat,[23] Waterfox, K-Meleon, Lunascape, Portable Firefox, Conkeror, Classilla, TenFourFox.

Other products using Gecko include Nightingale, Instantbird and Google's picture-organization software Picasa (for Linux).[24]

Gecko is also used by Sugar for the OLPC XO-1 computer.[25] Gecko is used as a complete implementation of the XUL (XML User Interface Language). Gecko currently defines the XUL specification.

Past users[edit]

Products that have historically used Gecko include Pale Moon (now currently using Goanna), Songbird, Epiphany (now known as GNOME Web) and GNOME DevHelp both have replaced Gecko with WebKitGTK, Sunbird (calendar), and other web browsers including Swiftfox, Flock, Galeon, Camino, Minimo, Beonex Communicator, Kazehakase, and MicroB.

Proprietary dependency[edit]

On Windows and other platforms, Gecko depends on proprietary compilers.[26] Thus, FOSS distributions of Linux can not include the Gecko package used in the Windows compatibility layer Wine.[27]

After Gecko 2.0, the version number was bumped to 5.0 to match Firefox 5, and from then on has been kept in sync with the major version number for both Firefox and Thunderbird,[28] to reflect the fact that it is no longer a separate component.[29]

Bloat[edit]

In the Netscape era, a combination of poor technical and management decisions resulted in Gecko software bloat.[11][30][31] Thus in 2001 Apple chose to fork KHTML, not Gecko, to create the WebKit engine for its Safari browser.[30][31] However, by 2008 Mozilla had addressed some of the bloat problems, resulting in big performance improvements for Gecko.[32]

Quantum[edit]

Quantum is a Mozilla project encompassing several software development efforts to "build the next-generation web engine for Firefox users". It includes numerous improvements to the Gecko, largely incorporated from the experimental Servo project. Quantum also includes refinements to the user interface and interactions.[12][33]

Firefox 57, released in November 2017, is the initial version with a Servo component enabled. Mozilla dubs this and several planned future releases "Firefox Quantum".[34][35]

Background[edit]

In 2013, Mozilla began the experimental Servo project, which is an engine designed from scratch with the goals of improving concurrency and parallelism while also reducing memory safety vulnerabilities. An important factor is writing Servo in the Rust programming language, also created by Mozilla, which is designed to generate compiled code with better memory safety, concurrency, and parallelism than compiled C++ code.[5]

As of April 2016, Servo needed at least several years of development to become a full-featured browser engine.[36] Thus the decision to start the Quantum project to bring stable portions of Servo into Firefox.

Component[edit]

The Quantum project is composed of several sub-projects.[12]

  • CSS: Servo's parallel style sheet system integrated into Gecko. Benchmarks suggest that performance scales linearly with number of CPU cores.[37] This was released in Firefox 57.[35]
  • Render: Servo's rendering architecture, called WebRender, integrated into Gecko. WebRender replaces the immediate mode drawing model with a retained mode model that is more easily accelerated by the GPU by taking advantage of CSS/DOM's similarity to a scene graph. Worst-case scenario rendering in testing exceeds 60 frames per second.[38]
  • Compositor: Gecko's existing compositor moved to its own process, isolating browser tabs from graphics driver related crashes. Since compositor crashes will not bring down the browser content process, the compositor process can be restarted transparently without losing user data. This was released in Firefox 53.[39]
  • DOM: Loosely inspired by Servo's Constellation architecture[40] and Opera's Presto engine,[41] Quantum DOM uses cooperatively scheduled threads within the DOM to increase responsiveness without increasing the number of processes and, thus, memory usage.
  • Flow: An umbrella for user visible performance improvements driven by a team that works across Gecko components. Currently focused on real user performance improvements on major webapps, primarily G Suite and Facebook.[42]
  • Photon: A UI refresh of the entire application, with a strong focus on improving UI performance. Treated as a sister project to Quantum Flow.[43] This was released in Firefox 57.[34]
  • Network: Improve the performance of Necko, Gecko's networking layer, by moving more network activity off the main thread, context dependent prioritization of networking streams, and racing the cache layer with the network.[44] This feature was released in Firefox 59.[45]

Azure[edit]

The Mozilla Azure project is a stateless low-level graphics abstraction API used in Firefox.[46] The project has several objectives including more accurate Direct2D compatibility, optimized state interoperability, and improved control over performance characteristics and bugs. Azure will provide 2D hardware acceleration on top of 3D graphics backends. Firefox began using Azure instead of Cairo in 2012.[47][48] It is written in C++ and used by Servo.[49] The Azure name is an ode to the early Netscape founder James H. Clark and his earlier work at SGI. Jim Clark invented Geometry Engine at Stanford University in 1979 which was the first GPU. Silicon Graphics were also the original inventors of OpenGL.[50]

References[edit]

  1. ^ "Mozilla Foundation End-User Licensing Agreements". Mozilla.
  2. ^ "Mozilla Licensing Policies". mozilla.org. Retrieved 2013-03-26.
  3. ^ "Embedding Mozilla". Mozilla.org. 2012-10-25. Retrieved 2012-10-31.
  4. ^ a b "Simple Firefox for Android build". Gecko is implemented using C++ and JavaScript.
  5. ^ a b Bergstrom, Lars; et al. (May 2016). "Engineering the Servo Web Browser Engine using Rust" (PDF). Proceedings of the International Conference on Software Engineering.
  6. ^ "Google Groups". groups.google.com.
  7. ^ Yegulalp, Serdar (February 3, 2017). "Mozilla binds Firefox's fate to the Rust language". InfoWorld.
  8. ^ "MPL 2 Upgrade". Retrieved 2012-08-18.
  9. ^ "Gecko FAQ". MDN Web Docs.
  10. ^ "nglayout project: identity crisis". Mozilla.org. Archived from the original on 2011-06-29. Retrieved 2012-10-31.
  11. ^ a b Jorge O. Castro (2004-06-15). "Ars Technica sits down with Scott Collins from Mozilla.org". Ars Technica. Retrieved 2017-02-16.
  12. ^ a b c d "Quantum". Mozilla Wiki. Retrieved 2017-04-20.
  13. ^ Cimpanu, Catalin. "Mozilla Announces Quantum, a New Browser Engine for Firefox". softpedia. Retrieved 2016-11-07.
  14. ^ "Firefox Focus 7.0 enters beta, Switches to GeckoView (Gecko Engine)".
  15. ^ a b "Firefox Focus with GeckoView". Mozilla Hacks. September 13, 2018. Retrieved September 4, 2019.
  16. ^ "What's new in Firefox Focus for Android (version 7) | Firefox Focus Help". support.mozilla.org. Retrieved September 4, 2019.
  17. ^ "GeckoView in 2019". Mozilla Hacks. June 27, 2019. Retrieved September 4, 2019.
  18. ^ "Mozilla CSS support chart". Developer.mozilla.org. 2012-08-04. Retrieved 2012-10-31.
  19. ^ "ECMAScript 5 support in Mozilla". Developer.mozilla.org. 2013-11-14. Retrieved 2013-12-02.
  20. ^ "Mozilla SVG Status". Mozilla.org. 2012-08-25. Retrieved 2012-10-31.
  21. ^ "Mozilla Adds Undetectable document.all Support, Part of New Novell Linux Distribution?". Developer.mozilla.org. 2004-07-23. Retrieved 2018-02-07.
  22. ^ "IE Uses Gecko Under Wine". Wine Wiki. Retrieved 2009-09-14.
  23. ^ sdubois (24 June 2010). "Gecko". Free Software Foundation. Retrieved 23 May 2019.
  24. ^ "Picasa 3.0 for Linux". Google. Archived from the original on 2009-01-07. Retrieved 2008-12-28.
  25. ^ Martens, China (2007-01-03). "One Laptop Per Child readies 'Sugar' interface". IDG News Service. Archived from the original on 2008-01-18. Retrieved 2007-12-28.
  26. ^ "Building Firefox for Windows". MDN Web Docs.
  27. ^ http://wiki.jswindle.com/index.php/Fedora#Working_Wine Archived June 11, 2012, at the Wayback Machine
  28. ^ "Gecko versions and application versions". MDN. Retrieved 2013-11-18.
  29. ^ "Not much in new Thunderbird 5, but roadmap looks promising". Ars Technica. Retrieved 2018-02-07.
  30. ^ a b Paul Festa (2003-01-14). "Apple snub stings Mozilla". CNET Networks. Archived from the original on 2012-10-25. Retrieved 2017-02-16.
  31. ^ a b David Baron (2003-01-09). "Thursday 2003-01-09". David Baron's weblog. self-published. Archived from the original on 2009-07-28. Retrieved 2017-02-16.
  32. ^ Ryan Paul (2008-09-09). "Why Mozilla is committed to Gecko as WebKit popularity grows". Retrieved 2017-02-16.
  33. ^ Cimpanu, Catalin. "Mozilla Announces Quantum, a New Browser Engine for Firefox". softpedia. Retrieved 2017-02-17.
  34. ^ a b "Firefox 57.0, See All New Features, Updates and Fixes". Mozilla. Retrieved 2018-10-30.
  35. ^ a b "Introducing the New Firefox: Firefox Quantum – The Mozilla Blog". The Mozilla Blog. Retrieved 2018-10-30.
  36. ^ "Servo remaining work". GitHub. Retrieved 2017-02-17.
  37. ^ "The Changelog". The Changelog. Retrieved 2017-03-28.
  38. ^ "Bay Area Rust Meetup February 2016". Air Mozilla. Retrieved 2017-03-28.
  39. ^ "Firefox faster and more stable with the first big bytes of Project Quantum, simpler with compact themes and permissions redesign". Mozilla Blog. Retrieved 2017-04-27.
  40. ^ "Servo Architecture". YouTube. Retrieved 2017-03-28.
  41. ^ "Mozilla's Quantum Project". Bill McCloskey's Blog. 2016-10-27. Retrieved 2017-03-28.
  42. ^ "Quantum Flow". Mozilla Wiki. Retrieved 2017-03-28.
  43. ^ dolske (2017-05-18). "Photon Engineering Newsletter #1". Dolske's blog. Retrieved 2017-07-04.
  44. ^ "TPE Necko/Projects - MozillaWiki". wiki.mozilla.org. Retrieved 2017-07-04.
  45. ^ "Firefox 59 Release Notes". www.mozilla.org. Retrieved 2019-01-16.
  46. ^ "Platform/GFX/Moz2D - MozillaWiki".
  47. ^ Parfeni, Lucian. "Firefox Now Uses the Azure Graphics API for Canvas on All Platforms".
  48. ^ "Azure Replacing Cairo In Mozilla Firefox - Phoronix".
  49. ^ Willis, Nathan (17 June 2015). "Parallel page rendering with Mozilla Servo". LWN.net. Retrieved 27 June 2015.
  50. ^ "Introducing the Azure project - JOEDREW!".

External links[edit]