mirror of
https://github.com/servo/servo
synced 2026-04-25 17:15:48 +02:00
Page:
Meeting 2015 09 21
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
This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
Servo Meeting 2015-09-21
Vidyo links:
- *** Early meeting: https://v.mozilla.com/flex.html?roomdirect.html&key=aiRAKuP7pjdJ (Servo)
- Late meeting: https://v.mozilla.com/flex.html?roomdirect.html&key=hn5vMQLsWV19 (ServoSamsung)
Reminder: use http://benjamin.smedbergs.us/weekly-updates.fcgi/
Agenda items
- layout meeting debrief (simon, pcwalton, mbrubeck)
- Should we be reviewing submodule updates as we pull them in? (larsberg)
- Exposed bugs (jdm)
- Use https://github.com/servo/skia-snapshots ? It’s 11 MiB to clone, vs 330 MiB for servo/skia (simonsapin)
- Master branch is now "protected" from accidental push (larsberg)
Attending
- brson, jack, pcwalton, manishearth, larsberg, simonsapin, jdm, edunham, mbrubeck, martin, ms2ger
Last week
Paris meeting stuff
- mbrubeck: We made plans for Fragmentation, pixel snapping.
- pcwalton: WebRast is coming!
- mbrubeck: gw has some awesome initial results and new demos to show them off.
Reviewing submodules
- larsberg: We often rubber-stamp PRs for updating external dependencies. It's been fine so far, but I'm curious what we want to do longer-term.
- mbrubeck: I try to scan the changes in the upstream repo. Kinda trusting upstream maintainers' master branches.
- jdm: Depends on the repository. Some have thorough reviews - don't mind random upgrades to hyper. But other ones?
- brson: How do we check license compatibility?
- larsberg: I scan them manually. There's an open issue to create a tidy.py extension to help with this. We've caught some issues already with GPL or LGPL code that we had to try to get reliscensed.
- jack: Next time we pull in new dependencies (including when we update to a new version of an existing crate that pulls in new downstream dependencies)... maybe we could get high-five to notify when new dependencies are added and need to be audited. I'm not sure we need to worry about dependencies of dependencies if we trust upstream maintainers to get it right...
- mbrubeck: I don't necessarily trust upstream devs to get licensing compatibility right if they don't have dedicated legal counsel.
- jack: Also for some new dependencies we end up with big blocks of code that don't get many eyes (like gaol, for example).
- pcwalton: For stuff like that I'm happy to do in-person reviews and walkthroughs since it's a lot of platform-specific stuff.
- jack: Being notified that stuff is added is a good first step. What about mozilla-central? It's in-tree, so I guess you can only link to system libraries or vendor stuff. Want a check that Cargo.lock that is built with is same that was present before. Could check that file at end of build is same as first.
- mbrubeck: Also makes people's working dirs dirty, so easy to notice.
- jack: Problem when forgetting to update gonk/cef lockfiles, since it can end up pulling in a more recent version that is released without any notice. This has happened a few times. I'm less worried about the one we all use for main development.
Exposing good bugs
- jdm: Maybe renaming the issue tags to be more reflective? Also, samfoo wrote a webpage that grabs issues from our tracker & can expose them in a nicer way. Removes ones marked as assigned, and highlights assigned ones that have not seen activity for several weeks. It's a new repo in our org: https://github.com/servo/servo-starters
- jdm: Current prototype is at: http://www.ifdown.net/servo-starters/
- jdm: Look at it & file issues!
- mbrubeck: I want to pull in issues from all of our repos.
- jack: Awesome! On tag renames, I agree with many of points. I'll comment further later. Where is it stored?
- jdm: It's a static webpage. If we want to use a GH account to avoid running out of API limits, can do as a Heroku app or something else that stores our secrets.
- jack: I'd sorta like this on servo.org.
- mbrubeck: Also see if other projects want to use it? e.g., Rust?
- brson: I'm intrigued and want it for Rust! Keep them separate, or share?
- jdm: Competition for bugs ahoy...
- jack: Seems like should just be able to list all the repos and tag names in config files, run from the same codebase but potentially separate.
- brson: Rust is creating another web app on Github around feature progression, the RFC process, etc. to report status. Basically a GH scraper. Don't know if it's relevant, but lots of this stuff is going on.
- jack: Seems like a simple template that manages github APIs and secrets etc. could be valuable, so we could all work from a common base. Who's doing the Rust one right now?
- brson: Maybe steveklabnik's partner?
- jack: I'll reach out to her and samfoo and see what we can do here.
- brson: Perhaps include rust-community?
Skia snapshots
- jack: We need to do something. It's the biggest complaint of new users. At least half a dozen bug reports of "broken build" because it takes so long. What's the easiest way? Blowing away a the skia repo?
- SimonSapin: If we do this, every time we make changes to or update skia from upstream, we have to run a script to update the repository. Not as convenient to perform skia updates as it is now.
- jack: What's the full proposal? Even if we just squash the history and just land updates it'd be good.
- SimonSapin: Yes. One repo with all of the history in case we want to
git blameand the other one with just one commit. - mrobinson: Can Cargo shallow clone?
- simonsapin: There's an issue, but it depends on libgit2, which seems to be unable to add support.
- manish: Yes, it can't add shallow clones without breaking other users of the library.
- simonsapin: The problem is that skia compresses to 11MB, but crates.io only supports 10MB.
- jack: Doesn't crates.io only store the cargo.toml? Can't we just tell acritchto to increase the limit? Or whitelist some owners to have a higher limit?
- simonsapin: they suggest breaking up skia.
- jack: no way.
- mrobinson: Maybe move the custom code out (to rust-azure?) and then not update skia very often? I think we've pulled out the C++ stuff?
- mbrubeck: Similar questions updating harfbuzz and packaging icu. ICU is not in git. harfbuzz is in git, but wanted to use their tarball, both so it's easy to map to a release and the tarball has the
make distrun on it so you don't have to rerun autotools stuff. Any opinions on that? Unpacking the release tarball into our repo, instead of closing the upstream? - jack: For C libraries, that seems like exactly what we want to do. Fontconfig is a good example - we only use the release tags against their git repo. If the repo was large, we'd want to flatten. Might as well use tarballs checked into git repos anyway. We're not getting any value from having the history in the Servo tree. Skia's a hard case because we do modify it, though we're pretty much done with that now. Flat history would be a huge win for the initial developer experience for Servo. Let's just make sure it's not super annoying. The update would be fine; just keeping it going is annoying. Skia mainly gets build fixes, which are on our side. So lots of hassle to update skia.
- simonsapin: Just running a script & pushing to a repo.
- jack: Can you file a bug about the crates.io size limit? Then we can discuss it.
- simonsapin: If that happens, we don't need snapshots of skia. Can just put it on crates.io and be done.
GitHub protection
- larsberg: I've disabled the ability of anybody to push to master. Need to go into settings as owner and disable that option in order to revert that protection. This doesn't prevent accidentally pushing mergeable changes over, just protects against rewriting history. We could also prevent merging any branch into master that doesn't pass github status checks. Might try that out on a dependency on first, but for stuff where we have homu automerging after running travis checks, that could prevent accidentally pressing the big green merge button.
- jack: Anybody adding new stuff to homu, the scripts that I posted are broken for 2FA. I can update them to take a new parameter for the OTP token. Lars, I think your script you used to gather accounts missing 2FA missed some people, since bors wasn't nagged.
- larsberg: Only nagged owners, so I made bors no longer an owner.
- jack: With bors not having 2FA, it has a long randomly-generated passwords. Not prey to lists of popular passwords.
- edunham: Where's the password live?
- jack: I have it, and jdm might have it from a GPG email long ago.
- larsberg: Not in the pillar?
- jack: I don't think so.
- manishearth: Isn't there an etherpad for research managers?
- larsberg: No, that has build machine passwords.
- edunham: If jack's computer spontaneously combusts, we've lost access?
- jack: jdm has it!