class: center, middle ###Contributing to #Servo ### 2016/8/27, TW Code Sprint ### Shing Lyu ??? top, middle, bottom left, center, right --- name: toc ###Agenda 1. What is Servo 1. Workflow 1. Build & Test 1. Code Organization 1. More Documentations 1. Project Ideas ??? This is a template --- ###what is Servo * A new browser engine * Written in Rust * Focus on performance, parallelism, and security --- ### Workflow ![contribution_flow](data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN" "http://www.w3.org/TR/2001/PR-SVG-20010719/DTD/svg10.dtd">
<svg width="47cm" height="24cm" viewBox="63 18 937 471" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="300.534" y="75.2841" width="139.55" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="370.309" y="107.284">
      <tspan x="370.309" y="107.284">Find a bug</tspan>
    </text>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="288.684" y="159.685" width="163.25" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="370.309" y="191.685">
      <tspan x="370.309" y="191.685">Fork &amp; clone</tspan>
    </text>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="298.585" y="244.087" width="143.45" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="370.31" y="276.087">
      <tspan x="370.31" y="276.087">Write code</tspan>
    </text>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="251.01" y="328.487" width="238.6" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="370.31" y="360.487">
      <tspan x="370.31" y="360.487">Create pull request</tspan>
    </text>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="269.76" y="412.889" width="201.1" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="370.31" y="444.889">
      <tspan x="370.31" y="444.889">Assign reviewer</tspan>
    </text>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="614.426" y="75.2841" width="102.7" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="665.776" y="107.284">
      <tspan x="665.776" y="107.284">Review</tspan>
    </text>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="603.276" y="240.389" width="125" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="665.776" y="272.389">
      <tspan x="665.776" y="272.389">Auto test</tspan>
    </text>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="600.551" y="412.889" width="130.45" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="665.776" y="444.889">
      <tspan x="665.776" y="444.889">Auto land</tspan>
    </text>
  </g>
  <g>
    <polygon style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="665.776,313.38 767.863,352.046 665.776,390.712 563.689,352.046 "/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="665.776" y="358.935">
      <tspan x="665.776" y="358.935">pass ?</tspan>
    </text>
  </g>
  <g>
    <ellipse style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" cx="150.88" cy="272.44" rx="72.8797" ry="42.4398"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="150.88" y="279.329">
      <tspan x="150.88" y="279.329">You</tspan>
    </text>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="370.309" y1="125.506" x2="370.309" y2="152.977"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="365.309,146.331 370.309,156.331 375.309,146.331 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="370.309" y1="209.908" x2="370.31" y2="237.379"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="365.31,230.733 370.31,240.733 375.31,230.733 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="370.31" y1="294.309" x2="370.31" y2="321.779"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="365.31,315.133 370.31,325.133 375.31,315.133 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="370.31" y1="378.709" x2="370.31" y2="406.181"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="365.31,399.535 370.31,409.535 375.31,399.535 "/>
  </g>
  <g>
    <polygon style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="665.776,142.832 744.111,182 665.776,221.168 587.441,182 "/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="665.776" y="188.889">
      <tspan x="665.776" y="188.889">OK ?</tspan>
    </text>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="665.776" y1="125.506" x2="665.776" y2="136.124"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="660.776,129.478 665.776,139.478 670.776,129.478 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="665.776" y1="221.168" x2="665.776" y2="233.681"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="660.776,227.035 665.776,237.035 670.776,227.035 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="665.776" y1="290.611" x2="665.776" y2="306.672"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="660.776,300.026 665.776,310.026 670.776,300.026 "/>
  </g>
  <g>
    <rect style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" x="509.548" y="75.2841" width="95.95" height="50.2222"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="557.523" y="107.284">
      <tspan x="557.523" y="107.284">Revise</tspan>
    </text>
  </g>
  <g>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="587.441,182 587.441,182.957 557.523,182.957 557.523,129.978 "/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="562.523,137.742 557.523,127.742 552.523,137.742 "/>
  </g>
  <g>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="557.523,75.2841 557.523,54.2841 640.101,54.2841 640.101,70.812 "/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="635.101,63.048 640.101,73.048 645.101,63.048 "/>
  </g>
  <g>
    <ellipse style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" cx="153.877" cy="436.156" rx="88.9191" ry="45.7658"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="153.877" y="428.934">
      <tspan x="153.877" y="428.934">Highfive</tspan>
      <tspan x="153.877" y="457.156">bot</tspan>
    </text>
  </g>
  <g>
    <ellipse style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" cx="878.167" cy="101.395" rx="69.159" ry="43.8963"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="878.167" y="108.284">
      <tspan x="878.167" y="108.284">Reviewer</tspan>
    </text>
  </g>
  <g>
    <ellipse style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" cx="900.097" cy="356.423" rx="99.1479" ry="49.5351"/>
    <text font-size="22.5778" style="fill: #ffffff;text-anchor:middle;font-family:sans-serif;font-style:normal;font-weight:normal" x="900.097" y="349.201">
      <tspan x="900.097" y="349.201">Bors-servo</tspan>
      <tspan x="900.097" y="377.423">bot</tspan>
    </text>
  </g>
  <g>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="563.689,352.046 563.689,353 533.535,353 533.535,129.978 "/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="538.535,137.742 533.535,127.742 528.535,137.742 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" x1="665.776" y1="390.712" x2="665.776" y2="406.181"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="660.776,399.535 665.776,409.535 670.776,399.535 "/>
  </g>
  <g>
    <path style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" d="M 297.5,103.68 A 287.62,287.62 0 0 0 223.759,272.44"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="295.81,112.74 299.004,102.026 288.516,105.899 "/>
  </g>
  <g>
    <path style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" d="M 223.759,272.44 A 55.8078,55.8078 0 0 0 246.923,351.809"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="237.793,353.8 248.927,352.784 241.434,344.486 "/>
  </g>
  <g>
    <path style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" d="M 285.196,187.593 A 205.756,205.756 0 0 0 223.759,272.44"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="282.14,196.281 286.924,186.176 275.97,188.412 "/>
  </g>
  <g>
    <path style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" d="M 223.759,272.44 A 45.0587,45.0587 0 0 0 296.084,272.886"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="296.499,282.251 297.423,271.108 287.955,277.054 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" x1="242.796" y1="436.156" x2="265.298" y2="437.695"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="257.211,442.154 267.529,437.847 257.893,432.177 "/>
  </g>
  <g>
    <line style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" x1="809.008" y1="101.395" x2="721.598" y2="100.444"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="729.416,95.5286 719.362,100.42 729.307,105.528 "/>
  </g>
  <g>
    <path style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" d="M 800.949,356.423 A 139.143,139.143 0 0 0 732.239,267.568"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="741.455,266.517 730.275,266.503 736.971,275.456 "/>
  </g>
  <g>
    <path style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" d="M 735.046,436.097 A 126.175,126.175 0 0 0 800.949,356.423"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="740.115,428.426 733.041,437.084 744.212,437.548 "/>
  </g>
  <g>
    <path style="fill: none; fill-opacity:0; stroke-width: 2; stroke-dasharray: 4; stroke: #ffffff" d="M 530.343,72.1534 A 187.984,187.984 0 0 0 223.759,272.44"/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 2; stroke: #ffffff" points="521.359,70.1411 531.958,73.6995 528.445,63.0853 "/>
  </g>
  <g>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="370.31,463.111 370.31,487.6 497,487.6 497,29.0992 665.776,29.0992 665.776,68.5759 "/>
    <polyline style="fill: none; fill-opacity:0; stroke-width: 3; stroke: #ffffff" points="660.776,61.93 665.776,71.93 670.776,61.93 "/>
  </g>
  <text font-size="22.5778" style="fill: #ffffff;text-anchor:start;font-family:sans-serif;font-style:normal;font-weight:normal" x="687.054" y="234.254">
    <tspan x="687.054" y="234.254">Y</tspan>
  </text>
  <text font-size="22.5778" style="fill: #ffffff;text-anchor:start;font-family:sans-serif;font-style:normal;font-weight:normal" x="566.356" y="175.902">
    <tspan x="566.356" y="175.902">N</tspan>
  </text>
  <text font-size="22.5778" style="fill: #ffffff;text-anchor:start;font-family:sans-serif;font-style:normal;font-weight:normal" x="681.054" y="406.152">
    <tspan x="681.054" y="406.152">Y</tspan>
  </text>
  <text font-size="22.5778" style="fill: #ffffff;text-anchor:start;font-family:sans-serif;font-style:normal;font-weight:normal" x="542.356" y="346.216">
    <tspan x="542.356" y="346.216">N</tspan>
  </text>
</svg>
) --- ### Claim a bug * [Servo Starters](https://starters.servo.org/) * Leave a comment in the issue * Ask questions in the issue or IRC --- ### Building & Testing * `./mach build -d`: debug build * `./mach build -r`: release build, required for running tests * `./mach build -d -j8`: 8 thread * `./mach test-*` * `./mach run -[d|r]` * `-w`: enable webrender * `-b`: enable browser.html * `./mach run -d --debug --debugger=gdb` --- ### Before Pull Request * `./mach build -d` * `./mach test-tidy` * Other tests * `./mach test-wpt`: DOM * `./mach test-css`: style, layout * `./mach test-unit` * Title examples: * Fixed something to resolve this problem * Added something to provide some benefit --- ### After PR created * `highfive` bot will assign reviewer for you (Ask for `r?someone`) * Reviewer will ask you to fix something * `git push` to your branch * Reviewer will `r+` (i.e. accept your patch) * When ready, run `git rebase -i` to squash, then `git push -f` * bors-servo will auto-test and merge your commit. --- ### Code Organization ```bash . ├── components # code! ├── tests # tests ├── python # mach tool and other ├── target # build output │ ├── debug │ └── release ├── docs # documentation │ # You probably won't touch ├── etc ├── ports ├── resources └── support ``` --- ### Source code ```bash components ├── servo # The main function ├── constellation # Where all the threads communicate ├── net # Network ├── script # DOM/JavaScript ├── style # CSS Rules ├── script_layout_interface ├── layout # Layout algorithms ├── layout_thread # The thread that runs the layout process ├── gfx # The graphics stack, font, etc. ├── compositing ├── msg ├── canvas ├── plugins ├── range ├── profile # Profiling ├── devtools # Developer Tools ├── webdriver_server # WebDriver for test automation ├── util └── *_traits ``` --- ### Infra & Tests ```bash . ├── python │ ├── mach │ ├── servo # Mach commands │ ├── tidy │ └── _virtualenv └── tests ├── unit ├── wpt │ ├── metadata # Test expectations │ ├── web-platform-tests │ ├── metadata-css # Test expectation for css tests │ ├── css-tests │ └── mozilla # Servo-specific ├── dromaeo # JS Benchmark ├── compiletest ├── heartbeats ├── html ├── jquery └── power ``` --- ### Other Repos * In [https://github.com/servo](https://github.com/servo) * `servo/webrender`: WebRender * `servo/saltfs`: CI stuff * `servo/servo.org`: The website * Various `rust-*` repos --- ### Documentations * Wiki: [https://github.com/servo/servo/wiki](https://github.com/servo/servo/wiki) * In-tree doc: [`docs/`](https://github.com/servo/servo/tree/master/docthub.com/servo/servo/tree/master/docss) * Code comments
* Trace code online: https://dxr.mozilla.org/servo/source/ --- ### Project Ideas * [`Taiwan Code Sprint` milestones](https://github.com/servo/servo/issues?q=is%3Aopen+is%3Aissue+milestone%3A%22Taiwan+Code+Sprint%22) * Flow Tree Dump: [#12675](https://github.com/servo/servo/issues/12675) - Refactor to serde - Debug the trigger point - Reuse the viewer * Profiler * Compatiable with Gecko * `./mach test-perf`: [#12792](https://github.com/servo/servo/issues/12792) - More followups [#13008](https://github.com/servo/servo/issues/13008) * Flexbox: [#12453](https://github.com/servo/servo/issues/12453#issuecomment-239611493a) --- ### Let's say Hi on the IRC * `#servo` on irc.mozilla.org * http://chat.mibbit.com/?server=irc.mozilla.org&channel=%23servo --- class: center, middle # Backup --- ### Full file tree ``` . ├── components │ ├── canvas │ ├── canvas_traits │ ├── compositing │ ├── constellation │ ├── devtools │ ├── devtools_traits │ ├── gfx │ ├── gfx_traits │ ├── layout │ ├── layout_thread │ ├── layout_traits │ ├── msg │ ├── net │ ├── net_traits │ ├── plugins │ ├── profile │ ├── profile_traits │ ├── range │ ├── script │ ├── script_layout_interface │ ├── script_traits │ ├── servo │ ├── style │ ├── style_traits │ ├── util │ └── webdriver_server ├── docs │ └── components ├── etc │ ├── ci │ └── doc.servo.org ├── ports │ ├── cef │ ├── geckolib │ └── glutin ├── python │ ├── mach │ ├── servo │ ├── tidy │ ├── tidy_self_test │ └── _virtualenv ├── resources │ ├── ahem │ ├── shaders │ └── user-agent-js ├── support │ ├── android │ ├── rust-task_info │ └── windows ├── target │ ├── debug │ ├── geckolib │ └── release └── tests ├── compiletest ├── dromaeo ├── heartbeats ├── html ├── jquery ├── power ├── unit └── wpt ```