mirror of
https://github.com/servo/servo
synced 2026-04-25 17:15:48 +02:00
Page:
Meeting 2014 01 13
Pages
Adding a new WebIDL binding
Alternative Logo Proposals and Related Swag
Asynchronous WebAssembly compilation project
Austin Oxidation
Autogeneration of style structs
Basic SVG support project
Beginner's guide to rebasing and squashing
Benchmarking
Benchmarks
Bots
Browser Engine Research
Build Errors FAQ
Buildbot administration
Building for Android
Building for Magic Leap
Building for UWP
Building on ARM desktop Linux
Building
CI Services we use
CSS parse error reporting
CSSOM student project
Canvas rendering project
Cargo upgrade service project
Code rust concurrency
Code Review
Code of Conduct
Coding standards
Compiler upgrade recipes
Compositor Layer Design
Contributing
Control Servo using WebDriver
Creating and viewing WARC web archives in Servo
Creating new OpenSSL Windows binary distributions
Cross compiling from linux to mac
Crowbot
Css selector matching meeting 2013 07 19
DOM Design
DOM documentation
DOM missing pieces
Debugging JS web compat issues
Debugging and editing tools
Debugging
Design
Developer tools student project
Devtools CSS errors
Devtools plans
Devtools
Diagnosing SpiderMonkey JIT issues
Eric Atkinson visit 2013 09 10
Events and sundry
Expand HTTP request response monitoring
Fetch improvement project
Firefox Reality release notes
FirefoxReality build
Firewall setup for servo master1
Focus student project
Form validation student project
GSoC project brainstorming
Garbage collected DOM
Getting started with layout
GitHub Labels
Github & Critic PR handling 101
Github workflow
Glossary
Governance
Graphics toolkit integration
HTML parser improvement project
HTMLElement binding conversion
HTTP archive support project
HTTP library requirements
Hawaii Rooting
High priority content for layout
Highfive
HoloLens 2 test plan
Home
How to generate GStreamer binaries for CI
Image load conformance student project
Image maps project
Implement HTML charset parsing project
Implement ImageBitmap project
Implement missing WebAudio automation student project
Implement support for missing XMLHttpRequest APIs
Implement worker modules
Implementing a web standard (RGSoC)
Improve specification conformance of unicode bidi library
Incremental flow tree construction
Infrastructure
Integrate xml5ever
Intern project brainstorming
Intern projects
JS objects, wrappers, and cross origin concerns 2013 08 07
Layout 2020
Layout Overview
Layout resources
Layout revamp ideas
Leo meyerovich visit 2013 07 22
Linux sandboxing
London Oxidation
London Security
Meeting 2014 10 27
Meeting 2014 12 08
Meeting 2012 02 08
Meeting 2012 02 16
Meeting 2012 07 20
Meeting 2013 04 01
Meeting 2013 04 15
Meeting 2013 04 22
Meeting 2013 04 29
Meeting 2013 05 06
Meeting 2013 05 13
Meeting 2013 05 20
Meeting 2013 06 03
Meeting 2013 06 10
Meeting 2013 06 14
Meeting 2013 06 17
Meeting 2013 06 24
Meeting 2013 07 01
Meeting 2013 07 15
Meeting 2013 07 22
Meeting 2013 07 29
Meeting 2013 08 05
Meeting 2013 08 12
Meeting 2013 08 19
Meeting 2013 09 09
Meeting 2013 09 16
Meeting 2013 09 23
Meeting 2013 09 30
Meeting 2013 10 14
Meeting 2013 10 21
Meeting 2013 10 28
Meeting 2013 11 04
Meeting 2013 11 18
Meeting 2013 11 25
Meeting 2013 12 02
Meeting 2013 12 09
Meeting 2013 12 16
Meeting 2014 01 06
Meeting 2014 01 13
Meeting 2014 01 21
Meeting 2014 01 27
Meeting 2014 02 03
Meeting 2014 02 10
Meeting 2014 02 24
Meeting 2014 03 10
Meeting 2014 03 17
Meeting 2014 03 24
Meeting 2014 03 31
Meeting 2014 04 07
Meeting 2014 04 14
Meeting 2014 04 21
Meeting 2014 04 28
Meeting 2014 05 05
Meeting 2014 05 13
Meeting 2014 05 19
Meeting 2014 06 09
Meeting 2014 06 17
Meeting 2014 06 23
Meeting 2014 06 30
Meeting 2014 07 07
Meeting 2014 07 14
Meeting 2014 07 21
Meeting 2014 07 29
Meeting 2014 08 04
Meeting 2014 08 11
Meeting 2014 08 12
Meeting 2014 08 18
Meeting 2014 08 25
Meeting 2014 09 08
Meeting 2014 09 15
Meeting 2014 09 22
Meeting 2014 09 29
Meeting 2014 10 06
Meeting 2014 10 13
Meeting 2014 10 20
Meeting 2014 11 10
Meeting 2014 11 17
Meeting 2014 11 24
Meeting 2014 12 15
Meeting 2015 01 05
Meeting 2015 01 12
Meeting 2015 01 26
Meeting 2015 02 09
Meeting 2015 02 23
Meeting 2015 03 02
Meeting 2015 03 16
Meeting 2015 03 30
Meeting 2015 04 06
Meeting 2015 04 13
Meeting 2015 04 27
Meeting 2015 05 04
Meeting 2015 05 11
Meeting 2015 05 18
Meeting 2015 06 01
Meeting 2015 06 08
Meeting 2015 06 15
Meeting 2015 07 06
Meeting 2015 07 13
Meeting 2015 07 27
Meeting 2015 08 10
Meeting 2015 08 17
Meeting 2015 08 24
Meeting 2015 08 31
Meeting 2015 09 14
Meeting 2015 09 21
Meeting 2015 09 28
Meeting 2015 10 05
Meeting 2015 10 12
Meeting 2015 10 19
Meeting 2015 10 26
Meeting 2015 11 02
Meeting 2015 11 09
Meeting 2015 11 16
Meeting 2015 11 30
Meeting 2016 01 04
Meeting 2016 01 11
Meeting 2016 01 25
Meeting 2016 02 01
Meeting 2016 02 08
Meeting 2016 02 22
Meeting 2016 03 07
Meeting 2016 03 21
Meeting Devtools Servo 2
Meetings
Microdata project
Minutes Hackathon 2012 03 27
Missing DOM features project
More ServiceWorker support project
More developer tools student project
Mozlandia Automation
Mozlandia B2S
Mozlandia JS
Mozlandia Rust In Gecko
Mozlandia WPT
Mozlandia gfx
Mozlando Devtools Servo
Mozlando Oxidation
Mozlando SM Servo
Mozlando Servo Bluetooth
Mozlando Servo MagicDOM
Mozlando Servo SMStrings
Mutation observer project
Mutation testing project
NCSU student projects
Network security project
Off main thread HTML parsing project
Offscreen canvas improvements project
Offscreen canvas project
Orlando Oxidation 2018
Oxidation 2015 11 05
Persistent sessions student project
Preparing ARM libraries for CI
Priority of CSS properties
Priority of DOM implementation
Priority of dom bindings
Private browsing student project
Profiling
Project proposal deadlines
Prototype JS form controls student project
Prototype ways of splitting the script crate
Publishing a new ANGLE NuGet version
Publishing a new app store release
Push vs Pull for caching
Random web content project
Refactor GLES2 student project
Refactor bluetooth support student project
Remaining work
Removing push notifications from IRC hooks
Replace C libraries student project
Report new contributors project
Representation of computed style
Research
Reviewer
Roadmap
Running Web Platform Tests on Servo
Rust HTML parser
Rust SpiderMonkey debugger API
Rust cssparser code walk 2013 08 02
SaltStack Administration
San Francisco Oxidation
Servo Benchmarking Report (December 2024)
Servo Benchmarking Report (November 2024)
Servo Benchmarking Report (October 2024)
Servo Layout Engines Report
Servo and SpiderMonkey Report
Servo for Gecko Developers
Specification Links
SpiderMonkey related tasks
SpiderMonkey infodump
SpiderMonkey upgrade details
Storage student project
Streaming webassembly student project
Strings
Student project brainstorm
Student projects
Styling overview
Stylo hacking guide
Summer of Code 2014: Implement XMLHttpRequest
Summer of Code 2016: Fetch API
Summer of Code 2016: File support
Summer of Code 2016: ServiceWorker infrastructure
Summer of Code projects
Summit meeting 2013 09 09
Support WebDriver based tests project
Syncing web platform tests (WPT)
TaskCluster
Testing
Tools
Tracking intermittent failures over time project
Transcription Notes from Servo Architecture talk in Suwon
Transcription notes from rust patterns talk in suwon
Transcription parallelism
Transcription rust concurrency
Transcription rust runtime
Transription layout and acid2
Trinity College Dublin student projects
UPenn student projects
Updating the Rust compiler used by Servo
Upgrading non taskcluster linux CI machines
Upgrading the UWP gstreamer binaries
Upgrading the windows LLVM binaries
Upgrading wptrunner
Using DOM types
Using Rust Spidermonkey Prototype
Using WebWorker Prototype
Version 0.1
Videos and presentations
WebAudio JS interfaces student project
WebAudio nodes student project
WebCompatBug
WebSocket student project
Webdriver student project
Webdriver tests student project
Webrender Overview
Whistler 2019 notes
Whistler Bugzilla
Whistler FFOS
Whistler GFX
Whistler Houdini1
Whistler Houdini2
Whistler Necko
Whistler Oxidation 2019
Work items for new contributors
Workweek COW DOM
Workweek alt js
Workweek android arm
Workweek boot 2 servo
Workweek compiler lints
Workweek displaylist
Workweek dogfooding
Workweek encoding
Workweek generated content
Workweek governance
Workweek graphics stack
Workweek graphics toolkit
Workweek incremental layout
Workweek js bindings status
Workweek layers
Workweek layers2
Workweek pixels
Workweek rasterization
Workweek reftests
Workweek roadmap
Workweek script crate
Workweek security
Workweek string interning
Workweek tables
Workweek writing modes
XML parser student project
infra triage notes
jQuery status
webxr.today support
Clone
3
Meeting 2014 01 13
Josh Matthews edited this page 2014-01-13 11:03:39 -08:00
Table of Contents
Agenda
- Tests
- fix and enable reftests
- jgraham's test harness work
- de-@ of Servo
Attending
- larsberg, jack, pcwalton, jdm, ms2ger (on faith), dherman, SimonSapin, jgraham, brson, azita, abinader
Testing story
- jack: Upgrade landed. The next project is getting testing in shape. I upgraded ref tests. Most still pass, but a few do not. Like to start gating builds on them, since process management is straightened out. Also, anybody else want to take it on?
- larsberg: I can.
- jack: Next step: jgraham has been building a test harness for FF for the W3C content tests. It was easy to add Servo support. I'd like to get this into Servo ASAP. We would import the w3c platform tests submodule into servo; copy the test harness from the gecko repo; create a dir for our current content tests; get all this running. Over time, we upstream content tests we develop into the w3c repo. Until upstreamed, keep in our own thing. End goal is running all of the web platform tests from the w3c with no servo-specific tests.
- jdm: That sounds unlikely.
- jgraham: Might need things for testing particulars of a GC at certain momements, etc.
- jack: So, the only ones we'd have separate would be the servo-specific ones. We'd need those if we ever do have async DOM apis, etc. if we're ahead.
- SimonSapin: what is the story for tests at w3c that are not in the web-platform-tests repository (CSS).
- jgraham: The CSS folks want their stuff separate. In theory, we could bring them in, but it only supports ref tests in gecko, not in servo. Maybe we could pull them in and use the same infrastructure as the platform tests if servo supports it. I've been focusing on the platform tests for now.
- jack: I will look at this unless somebody else is interested? Are there other tests besides the CSS ones that we should be working on?
- jgraham: No. The other obvious thing is the javascript tests. But since we don't have our own engine, it's not as relevant.
- dherman: There's core spidermonkey, but also some integration ones for spidermonkey & DOM, right? Are those relevant?
- jdm: Not aware of anything in particular.
- dherman: Guess I'm thinking of the standalone shell...
- jdm: That's more XPcom-related stuff (xpcshell).
de-@
- jack: We're one commit short in Rust of the de-@mut of servo. I took the commit before that one, cherry-picked debug info, and have disabled static linking. Static linking should get fixed by updating the toolchain on the build slaves. So, the only thing left is getting rid of @ and @mut as blocking future Rust upgrades. Seems reasonable to do this early so it doesn't get terrible. Volunteers? Should be straightforward, but it's a little ugly due to explicit borrows and the temporary lifetime issue in Rust (which leads to 2 lines of code every time you want to do a borrow).
- pcwalton: niko wanted to land the lifetime fix last week, so hopefully next week.
- jack: Shouldn't block our own work. We can search/replace those two lines. We have them because of Rc<RefCell<>>?
- jdm: I can get rid of the DOM-related ones with JSManaged to avoid rebasing over the RefCell stuff.
- jack: The DOM is probably the biggest one. then platform.
- larsberg: And windowing. jack: Ok, if you can do that, jdm, that would be great, and we can pick up the rest.
- larsberg: Yeah, we got prety far behind.
- jack: Just owned closures were tough. Linked task failure turned out to be the biggest problem for us. Hopefully nothing else that large!
- brson: Was anything really obnoxious to you?
- jack: It's unclear. My first response is losing linked task failure sucks. A lot. Maybe we'll find alternatives to this problem.
- brson: Is there a good pattern that doesn't require deep scheduler integration?
- jack: There were all these weird bugs after porting syntax. And it ended up being that we depended that when a task comes down, the whole of servo comes down. Now, nothing happens.
- larsberg: losing linked task failure caused us to have to explicitly handle a lot of shutdown protocols that "just worked" before.
- jack: Feels fragile now. But I had no issues with the native/green split. We run native start, launch the profiler, start a green scheduler pool for the constellation (so JS, layout, pipeline is in green threads) and then run the compositor on the main native thread. We haven't had any trouble.
- brson: spidermonkey?
- jack: It's on a green thread. It's what we seem to want, right?
- brson: I thought there were obstacles. Doesn't it use TLS?
- jdm: That's a concern!
- jack: We had it on a green thread until we found the post-summit bug, when we put it in 1:1 mode. Otherwise, it's always beeen there. If spidermonkey gets its own thread, we won't be able to do the fast context switch thing between it and layout. So the goal is to try to make it work... Most of the stuff in the Rust upgrade, as painful as it was, is that Rust got more strict, which caused us to stop taking advantage of the unsafety, etc. Servo is always safer after the upgrades. Especially the lifetime temporaries thing, it feels like the first couple of passes with external iterators, where we went backwards a bit in design before moving forward.
workweek
- SimonSapin: Agenda for next week?
- jack: I'll send it out soon. The plan is to work on stuff related to ACID2 that we all need to be together for. Tables, positioning, generated content, stacking contexts/z-index.
- SimonSapin: generated content. Some has landed, but we're still missing generation.
- jack: I'll try to send it out in the next couple of days.
- azita: Do you know if we have our space in SF?
- jack: No mail yet. I'll follow up. And check on hotel accomodations.
review queue
- jack: Stacked up PRs because we basically closed it for the upgrade. Can we try to empty it? ~24 PRs open right now. If your patches got whacked, sorry! Let me know if you have questions about the rebase. Mainly affect patrick because the new layout safety is quite different.
Servo publicity
- brson: I don't do twitter. Are we getting enough out about Servo? Is it being publicized?
- jack: We should do more about that. TWiR now has TWiS! Next easy thing is to have a servo talk at the monthly meetups.
- dherman: Don't need to tie Servo and Rust together. Different crowds. We would like to get interest from people not necessarily contributing to the codebase. One thing is nightly builds would make it possible for people to kick the tires. Maybe not advertising it too much because we're too early to have people use it? But a place where you can find it and try things out, that would be interesting. Also, a website would be nice (servo.org just goes to the github repo).
- jack: Logo! Stickers! How did that work with Rust?
- dherman: We contracted(?) to Shawn Martell.
- brson: I think he also did the FF logo, or worked on it, right?
- dherman: azita and I will get on this.
- jack: We have the infra to do servo nightlies (static linking). Need to get that quickly because the last brendan demo was a bit chaotic. It will be no less so, so sooner would be better.
- dherman: Even one platform would be great.
- jack: Experiment during workweek? Maybe a make package that will get a static build.
- dherman: Do we have a moz-servo twitter account? Yes. It's never tweeted. Probably created by me. Maybe Andreas? I'll look into it. Not necessarily a huge amount of traffic.
- azita: Both on Rust & Servo, trying to talk more internally at Mozilla. Maybe in Monday meeting mention something about Rust, releases, etc. A tutorial would also be great (internally).
- larsberg: Niko is working on a small tutorial for POPL that maybe could go out.
- dherman: We'll need a better tutorial at 1.0 for Rust. First set of materials would be useful for us to build off of. Training for Rust within Mozilla is great, for testing, building Mozilla interest, etc. Maybe for Servo, too? A brownbag on how Servo works? Put some into the talk on how to dive in / contribute, maybe we'd get some more interest.
- jack: A follow-up to the Summit session? Or we could also have a Servo hack day the next time one of those DOM implementation things come up that has a huge list of small things to pull together. Might be a bunch of that stuff in the ACID2/ACID3 stuff as well. I'll follow up on Twitter, etc. We can chat more next week, too.
- dherman: A simple thing is if there's a big enough milestone, get it onto HN. Need some sort of a web page - blog with announcements, on Mozilla Research blog, even a github commit at worst (boo).
- jack: Once we have table layout and ACID2, we can do wikipedia well. I don't even know what's left for wikipedia after ACID2. A little time on a browser shell for zoom/pan, etc. it'd be a good release. It could be a wikipedia browser. Just opens wikipedia and doesn't go anywhere else. Maybe a little instrumentation to show parallelism, gains, etc.
- jack: Next week (workweek) we should start seeing what ACID2 looks like with current servo. Showing the progress would help build momentum. During the workweek, it looked pretty bad. Passing ACID2 will be good. It's harder to find these visual things post-ACID2. ACID3 is non-visual. And then there's no more easy visual benchmarks.
- dherman: At that point, we invent our own.
- pcwalton: ACID3 has a score. Everybody likes scores!
- jgraham: ACID3 is the point where "making pretty things" no longer worked anymore. People would do the minimum to make it render right. For ACID3 people would implement stub interfaces just to pass the test, so it wasn't really helping.
- jack: Guess I know how we'll pass ACID3 :-) After ACID3, most of what we need to show is web features. So we can pick pages we render nicely. We'll need other ways for people to see why servo's goodness. Just being safe and easy to modifiy doesn't work. The Shumway viewer (framerates, etc.) is something I keep thinking of to show how we compare. Page rendering tests against FF / Blink, etc. I assume our path looks like that post-ACID3.