mirror of
https://github.com/servo/servo
synced 2026-04-25 17:15:48 +02:00
Page:
Workweek dogfooding
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
1
Workweek dogfooding
jdm edited this page 2014-11-11 07:00:12 -08:00
Servo workweek - dogfooding experience
UI / Chrome approach
- dherman: What should we do for UI appearance and chrome?
- kmc: Maybe use Fennec shell?
- dherman: Bad idea to use Firefox shell on desktop; there we should try to do something with maybe a UI designer.
- zwarich: If you put it on Android, then all the people who have to use iPhones can't use it
- pcwalton: Cross-platform even OSX and Linux is not a good idea.
- zwarich: Need to be platform-specific.
- mrobinson: How about just using the Web Platform and being largely chromeless.
- kmc: Need for Gaia anyway.
- zwarich: For a browser, bad for perf long-term
- pcwalton: Eventually, should be good enough. Only near-term thing I can think of is custom shells for OSX & Linux. That's just a fair amount of work. For a throwaway, it doesn't make sense. Being Chromeless (as we've done so far, but maybe using CEF) balances the work we need to do.
- dherman: Minimalism hides many design issues.
- pcwalton: Biggest problem is the lack of a URL bar.
- dherman: Came up in security - how much flexibility. Probably, once we start releasing binaries, how far along is the quality? The first version may just be wikipedia, so no UI at all. Or a fixed set of sites for this prepreprepreview, you just get a dropdown with 5 sites. Want to think about first impressions - how will this look and are there embarrassments?
- pcwalton: My biggest concern is linux graphics driver bugs. Distro issues, subpixel text, graphics driver bugs, etc. It's just so sad. It's not worth spending time on.
- mbrubeck: Only GPU rendering?
- kmc: Just worse with GPU. We may have to do software compositing with offscreen mesa so there's a safe mode.
- zwarich: Performance claims on Linux on top of X seems ridiculous.
- dherman: How big of a segment of the tech elite audience is on Linux?
- jack: Lots.
- pcwalton: Especially people who are Mozilla-friendly.
- mbrubeck: It's not a number that's grown in the last decade, but it hasn't shrunk either.
- pcwalton: It's big in the early adopter crowd, which is linux, but not the hip OSX Web N.0 crowd.
- dherman: We should not antagonize our Linux friends, but should acknowledge what the limits are to what we can do to have a great experience on Linux.
- pcwalton: Issue is - do we have a basic layers fallback implementation for Linux and XP? One of the big things I did during FF Android mobile was go GL layers only without a fallback. I don't see a point in investing in Linux+X - Wayland is in much better shape.
- dherman: Good. Investing in Wayland support on Linux sounds better.
- larsberg: Be Wayland-only?
- mbrubeck: Going back to Chrome, if it's a bar with a text file where you can type a URL, then if it's something we can fill in during our development, it's a nice entry point for people who want to contribute to Servo. They can make our stupid URL bar look prettier; have a Reload button; etc.
- pcwalton: There's a huge chasm between Chromeless and Chromeless+URL bar. Immediately you're no longer using cross-platform toolkit stuff like glutin.
- mbrubeck: I was envisioning glutin, and just having a rect within Servo, use conrad or the piston GUI API to put stuff there. Then anybody in Rust can build some stuff to extend it.
- kmc: Can do a servo shell with piston/conrad.
- mbrubeck: Yes, that could evolve.
- dherman: If we started the basic bits, that's great.
- larsberg: Should we be talking about dogfooding on desktop? We only care about mobile now.
- pcwalton: Desktop, but let's talk about it...
- jdm: Let's talk about features we need for dogfooding
Features we need for dogfooding
- jdm: Here are some issues that are required to view basic pages: https://github.com/servo/servo/milestones/Dogfooding
- jack: Probalby need some jQuery stuff. innerHTML, etc.
- kmc: Also need fragment parsing.
- gw: Don't you need jQuery for basically every website?
- jdm: Things on this list include iframes that load. And getting a load event that reflects when things have loaded. Cookies.
- simonsapin: Basic jQuery functionality, or the whole test suite?
- jdm: Just enough to not block further JS.
- kmc: Would be nice to grab the test suite, ala WPT, and mark known regressions.
- jdm: We do that in FF.
- cgaebel: And bootstrap, too.
- jack: Is libeditor in there?
- jdm: Forms / textarea? Yes.
- jack: This has layout text area, but we need to type things in it...
- mbrubeck: Document.write?
- kmc: Yes, it's very common. And not much work at this point.
- jack: I bet nobody'd notice. it's not used for anything other than ad networks.
- mbrubeck: It's more that when document.write fails, it stops script running.
- gw: I thought it's widely used...
- jack: My understanding is that's primarily in ad network code.
- jdm: element.style
- pcwalton: That's the largest thing I immediately run into. That's most of jQuery.
- jack: We have AJAX, so if we had style and innerHTML, we'd be pretty much there.
- gw: getComputedStyle?
- kmc: Not sure.
- dherman: When you talk about dogfooding, do you have a concrete set of websites.
- jdm: Github and Critic, for me.
- pcwalton: HN.
- kmc: Rust language docs with the search bar working. Doesn't even need cookies.
- gw: etherpad
- zwarich: content-editable is unrealistic. Probably even in 2015.
- bruno: MDN.
- jdm: DOM SPEC!
- pcwalton: doesn't it work?
- bruno: Needs document.write.
- dherman: I'd expect github and MDN to be hard
- jdm: We are parasites! We don't need to edit MDN :-)
- manish: IRCCloud?
- zwarich: Hard...
- pcwalton: Twitter. Not a lot of editing requirements there...
- dherman: Good scrolling dogfooding test.
- mbrubeck: Have Servo read the firefox cookie jar!
- zwarich: No. Don't. Totally insecure.
- kmc: Maybe just a readonly cookie jar...
- pcwalton: Just make cookies work. Send them up to the constellation.
- jdm: There's someone working on cookies right now. There will be a PR soon. It's a resource task.
- pcwalton: Just want it sandboxed; sounds fine.
- cgaebel: reddit
- jack: I need to be able to vote!
- kmc: In dogfooding, our resource loading is slow and synchronous; we should fix that.
- pcwalton: Yes, and in line with all of our goals.
- jack: Network stack needs some attention.
- kmc: Also moving off rust-http.
- zwarich: Lots of things wrong with page and resource loading right now that need to be fixed.
- pcwalton: I like twitter, wikipedia, reddit, HN, github. Lots of simple sites. What's blocking me personally is CSSOM, not logging in, and URL bar. At that point, I'd use it for simple things. I like how smooth the graphics are.
- kmc: Not as smooth on linux, which makes it harder for us to adopt...
- pcwalton: You could fix those issues!
- jack: Or we could buy pcwalton a linux box...
- dherman: One purpose of dogfooding is getting it on your critical path. Fix the papercuts.
- mbrubeck: URL fixup would be great.
- jdm: Funny you mention that!
- simonsapin: On the commandline, we have to distinguish file from domain names.
- mbrubeck: If the file exists open, otherwise...
- kmc: Is there a spec?
- simonsapin: There is no commandline spec.
- kmc: URL bar?
- simonsapin: No.
- kmc: Then we can do something reasonable and write the spec?
- mbrubeck: FF has a huge complicated thing. Would like defaulting to http://
- simonsapin: Why not https://?
- kmc: I like that.
- larsberg: Facebook?
- zwarich: Desktop is hard. Dynamic loading is hard.
- larsberg: Maybe mobile? Their native app is terrible.
- dherman: Probably not.
URL bar
- dherman: I like the idea of doing something small and getting volunteers or designers involved.
- pcwalton: My idea with rust-alert was to bridge the gap between things like glutin and monkeypatching the window that glut was popping up with.
- jack: Rust-whatever worked fine, just broke in linux.
- pcwalton: Just add a URL bar natively on each platform via the native widnow handle? Really not bad.
- kmc: Maybe we shouldn't put in the work, but there are tons of rust gamedevs who might want to do it.
- mbrubeck: In the windowing API, instead of passing it in, you can specify the viewport for Servo to draw to. That's the goal for the app that creates the window not to have to give the whole thing to Servo.
- pcwalton: Maybe making our own cross-platform miniui (like minibrowser) isn't a bad idea.
- jack: We have 2 platforms. Why be cross-platform?
- zwarich: If you have ever tried to write cross platform GUIs, you would not want to.
- dherman: Agreed, so do not try to abstract.
- zwarich: Just put a URL field and back/forward. Also, per-platform, how do you composite GL content with the window?
- jack: Can't we just use CEF?
- mbrubeck: Can we just use CEF?
- jack: I know GTK and can do Linux.
- pcwalton: I'll do OSX.
- jack: Put it in ports.
- zwarich: Chrome directory.
- kmc: Name is confusing.
- dherman: Very careful with naming. Don't make this look like a product from Mozilla.
- zwarich: Fortunately, a screenshot will make that clear :-)
- dherman: Careful edge here. Don't want to sound too much like a real product.
- mbrubeck: More about the directory structure.
- jack: We should not call anything Chrome.
- mbrubeck: We need to replace the binary.
- jack: Maybe examples/
- pcwalton: Or tools/
- dherman: More repos?
- pcwalton: Sure. Have to test that later.
- jack: In-tree for now.
- pcwalton: We'll use native controls for now for our chrome.
- zwarich: The native controls give you a consistent look with the rest of the applications on the platform.