Teams? > ?

Rendering Core


The rendering core team is a long-term engineering team that owns the overall rendering pipeline and most of the core rendering stages. Specifically style, layout, compositing, and paint. The team is also responsible for text, fonts, editing, canvas, images, hit testing, and SVG.

The team is made up of contributors from many different companies and see regular contributions from many more as well as from individual contributors.

Last updated: Thu?Oct 29, 2019 by Chris

Team Charter

The rendering core team is focused on the architectural principles of reliability, performance and extensibility of the core rendering technologies of the web: HTML, DOM and CSS. We also make sure to satisfy top requests from customers. Our primary customers are web developers and other teams within Chrome which build features on top of rendering.

Priorities

Scalable Performance

  • Rendering update performance is proportional to the amount of change, and “amount of change” has an intuitive explanation.
  • Rendering performance of a component need not depend on where it's put within a containing document, or the size of that document.
  • Rendering performance of a document need not depend on the size of components contained within it.
  • Same goes for encapsulation - a component can be included without breaking a containing page, and a containing page cannot break a component.

Reliability

  • Rendering features work correctly and have rational, understandable definitions.
  • Rendering features work the same on all platforms, and on all browsers.

Extensibility

  • Web developers can extend the capabilities of Rendering in novel ways without performance or ergonomic penalties.
  • Chromium developers can extend or embed the Rendering code in new and novel ways without excessive effort or performance penalties.

Ongoing Projects

List of ongoing major projects owned by the team or involving multiple team members.

  • CSS Containment
    Ongoing work to optimize performance isolation for CSS containment.
  • LayoutNG, issue 591099.
    A new layout system for Blink designed with fragmentation, extensibility and interruptibility in mind.
    Phase 1 (block flow) launched in M77.
    Further layout modes (tables, flexbox, grid) and block-fragmentation support targeted for 2020.
  • Composite After Paint (CAP), issue 471333.
    Previously known as Slimming Paint v2. Project to re-implement the Blink<->CC picture recording API to work in terms of a global display list rather than a tree of cc::Layers. It will result in a drastic simplification of the way that composited layers are represented in Blink and cc, which in turn will yield improved performance, correctness and flexibility.
  • src: local() matching, issue 627143.
    Font matching and IPC improvements to allow for spec compliant font matching and improved web font performance.

Organization

Team organization and communication.

Mailing lists

We use a set of public mailing list for technical discussions, questions, and announcements. Access is currently limited to subscribers but anyone may join by posting to the relevant list or following the web archives links below. Once subscribed the full historic archives are available.

  • [email protected]
    Primary list for the team. Used for non-technical and generic technical discussions as well as for announcements.
  • [email protected]
  • DOM team-specific list for technical and standards discussions.
  • [email protected]
    Style (CSS) specific list for technical and standards discussions.
  • [email protected]
    Layout, text, and font specific list for technical and standards discussions.
  • [email protected]
    Paint, Compositing, and SVG specific list for technical and standards discussions. Also see this site.

Weekly Meeting

There is weekly meeting held over video conference on Mondays open to all team members, the meeting notes of which are available below and sent out to the public mailing list. If you're interested in participating please talk to Emil or Chris and they'll share instructions.

Current schedule:

  • Tuesday 10:00 PST (13:00 EST, 18:00 BST, 19:00 CET; Wednesday 03:00 JST, 05:00 AEDT).

Meeting notes are public and are sent to rendering-core-dev, they're also available in this document: Meeting notes.

Slack

There is also a set of dedicated slack channels for the team. For logistical reasons these are limited to team members and collaborators. Please talk to one of the team members and they'll get you added as needed.

IRC

Many of the team members may also be found in the #chromium channel on freenode.

Team Members

  • Adenilson Cavalcanti adenilson.cavalcanti ARM San Jose Performance
  • Aleks Totic atotic Google Mountain View Layout, Paint
  • Anders Hartvoll Ruud andruud Google Oslo Style, Houdini
  • Chris Harrelson (lead) chrishtr Google San Francisco Paint, Compositing
  • Christian Biesinger cbiesinger Google New York Layout, Flexbox, Containment
  • David Grogan dgrogan Google San Francisco Layout, Tables, Flexbox
  • Dominik R?ttsches drott Google Helsinki Text, Fonts
  • Fernando Serboncini fserb Google Montreal Geometry, Canvas
  • Fredrik S?derquist fs Opera Link?ping SVG
  • Ian Kilpatrick ikilpatrick Google Mountain View Layout, Houdini, Standards
  • Javier Fernandez jfernandez Igalia A Coru?a Style, Layout, Grid
  • Joey Arhar jarhar Google San Francisco DOM
  • Koji Ishii kojii Google Tokyo Layout, Text, Fonts
  • Manuel Rego rego Igalia A Coru?a Layout, Grid
  • Mason Freed masonfreed Google San Francisco DOM
  • Morten Stenshorne mstensho Google Oslo Layout, Fragmentation, MultiCol
  • Philip Rogers pdr Google San Francisco Paint, Compositing
  • Richard Townsend richard.townsend ARM San Jose Layout, Performance
  • Rune Lillesveen futhark Google Oslo Style, Houdini, Standards
  • Stefan Zager szager Google San Francisco Layout, Lifecycle
  • Stephen Chenney schenney Google Atlanta Paint, Perf tracking
  • Vladimir Levin vmpstr Google San Francisco Paint, Containment, Async
  • Xianzhu Wang wangxianzhu Google San Francisco Paint, Compositing
  • Xiaocheng Hu xiaochengh Google Mountain View Text, Editing
  • Yoshifumi Inoue yosin Google Tokyo Editing
  • Yu Han yuzhehan Google San Francisco DOM

The list above is auto-generated, don't try to edit it directly. Instead please talk to Emil and he'll gladly add you or make the requested changes.

Contributing

If you're interested in getting involved and contributing to rendering there are many ways you could help and we'd love to have you. These range from filing good bug reports to creating test cases, reducing and triaging failures, fixing bugs and implementing new functionality.

Please see the chromium getting involved guide for generic advice and to help you get set up.

A good way to get started is to fix an existing bug. Bug fixes tend to be limited in scope, uncontroversial, and easy to evaluate.

Going through the bug database to find a suitable bug is quite a daunting task though. To make it a little easier we try to maintain a list of bugs that we think are suitable starter bugs. Those bugs are marked with a GoodFirstBug label. Use the following queries to see GoodFirstBug in the style & layout and paint & compositing components respectively.
If you prefer, the following queries will show all open bugs in the respective bucket: style & layout, paint & compositing.

Documentation

For a high-level overview of the rendering pipeline please see the Life of a Pixel (slide deck) talk that Steve Kobes gave a little while ago. It gives a very good overview and explains how the different steps in the pipeline work and interact with each other.

For more in-depth documentation about specific rendering stages see the relevant markdown files checked into the main source tree. The README.md file in each top level directory is a good starting point. Some of the key documents are linked below.



Design Documents

Each new feature and all major projects require a design document before the implementation work may commence. These documents are updated during the implementation phase and provides a detailed explanation of the feature or project as well as the history and the motivation.

Please add new design documents to the bottom of this list. Make sure they're world readable and, if possible, grant comment privileges to [email protected] rather than Anyone with a chromium.org account as not all contributors have chromium.org accounts.


Google-internal design documents (aim is to migrate them to the list above; on request we can try to make part/all public)


Bug & Triage Policy

The rendering core team is responsible for all bugs for the components listed below, including sub-components . Our policy is that all new bugs are to be triaged within a week of being filed and all P-0 and P-1 bugs are to be fixed in time for the next release. Failures to meet the policy is tracked in our weekly meeting and shared as part of the meeting notes

Policy

  1. Triage all bugs within 7 days.
  2. Fix P0 bugs within 15 days.
  3. Fix P1?regression?bugs within 15 days.
  4. Re-triage all bugs every 365 days.

Links

Related Teams

評論