-
Notifications
You must be signed in to change notification settings - Fork 27
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Ported Web Inspector docs from trac.webkit.org
- Loading branch information
1 parent
f084770
commit 4644cb7
Showing
7 changed files
with
1,101 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,144 @@ | ||
# Introduction | ||
|
||
The Web Inspector allows you to view the page source, live DOM hierarchy, script debugging, profiling and more! | ||
|
||
## Enabling the Web Inspector | ||
|
||
### Safari | ||
|
||
* Enable the Develop menu option in the Advanced preferences. | ||
* Use the optional toolbar button, Develop menu or Inspect Element context menu to access the Web Inspector. | ||
|
||
### Other WebKit clients | ||
|
||
* Find the application's bundle identifier. | ||
* Enter the following command once in Terminal (inserting the bundle identifier) | ||
|
||
``` | ||
defaults write "bundle-identifier-here" WebKitDeveloperExtras -bool true | ||
``` | ||
|
||
* Relaunch the application in order to use the Web Inspector | ||
|
||
## Using the Web Inspector | ||
|
||
The Web Inspector can be opened by '''right clicking anywhere on a web page''' and choosing '''Inspect Element'''. Once open, it highlights the node on the page as it is selected in the hierarchy. You can also search for nodes by node name, id and CSS class name. | ||
|
||
The Node pane shows the current node type and name, as well as any element attributes. | ||
|
||
Under the Style pane we show all the CSS rules that apply to the focused node. These rules are listed in cascade order with overridden properties striked-out—letting you truly see how cascading stylesheets affect the page layout. All shorthand properties have a disclosure-triangle to show and hide the expanded properties created by the shorthand. | ||
|
||
The Metrics pane provides a quick visual look at how margins, borders and padding affect the current node. | ||
|
||
Various HTML and JavaScript properties, including length of text nodes, offsetWidth/Height, class names, and parent/sibling information are vieweable in the Properties pane. | ||
|
||
See [Safari User Guide for Web Developers](http://developer.apple.com/safari/library/documentation/AppleApplications/Conceptual/Safari_Developer_Guide/UsingtheWebInspector/UsingtheWebInspector.html) for more details on other panels of the Web Inspector. | ||
|
||
## Hacking on the Web Inspector | ||
|
||
Most of the Web Inspector's code is HTML, JavaScript, and CSS—so it's very easy to implement new features and fix bugs! | ||
|
||
[List Web Inspector bugs and feature requests](http://tinyurl.com/2vqypl) | ||
|
||
## Related Blog Posts | ||
|
||
* [Introducing the Web Inspector](http://webkit.org/blog/41/introducing-the-web-inspector) | ||
* [Yet another one more thing… a new Web Inspector!](http://webkit.org/blog/108/yet-another-one-more-thing-a-new-web-inspector) | ||
* [Web Inspector Redesign](http://webkit.org/blog/197/web-inspector-redesign) | ||
* [Web Inspector Updates](http://webkit.org/blog/829/web-inspector-updates/) | ||
* [State of Web Inspector](https://www.webkit.org/blog/2518/state-of-web-inspector/) | ||
|
||
## Shortcut Keys | ||
|
||
### Safari | ||
|
||
| | Mac | Windows / Linux | | ||
|----------------------------|-------|------------------| | ||
| Toggle Web Inspector | ⌥⌘I | Ctrl-Alt-I | | ||
| Show Error Console | ⌥⌘C | Ctrl-Alt-C | | ||
| Start Profiling Javascript | ⌥⇧⌘P | Ctrl-Alt-P | | ||
|
||
### Web Inspector | ||
|
||
| | Mac | Windows / Linux | | ||
|-----------------------------|-----|-----------------| | ||
| Next Panel | ⌘] | Ctrl-] | | ||
| Previous Panel | ⌘[ | Ctrl-[ | | ||
| Toggle Console | ⎋ | Esc | | ||
| Focus Search Box | ⌘F | Ctrl-F | | ||
| Find Next | ⌘G | Ctrl-G | | ||
| Find Previous | ⇧⌘G | Ctrl-Shift-G | | ||
|
||
### Console | ||
|
||
| | Mac | Windows / Linux | | ||
|-----------------------------|----------|-----------------| | ||
| Next Suggestion | ⇥ | Tab | | ||
| Previous Suggestion | ⇧⇥ | Shift-Tab | | ||
| Accept Suggestion | → | Right | | ||
| Previous Command / Line | ↑ | Up | | ||
| Next Command / Line | ↓ | Down | | ||
| Previous Command | ⌃P | | | ||
| Next Command | ⌃N | | | ||
| Clear History | ⌘K or ⌃L | Ctrl-L | | ||
| Execute | ⏎ | Enter | | ||
|
||
### Elements Panel | ||
|
||
| | Mac | Windows / Linux | | ||
|-----------------------------|--------|-----------------| | ||
| Navigate | ↑ ↓ | Up/Down | | ||
| Expand/Collapse Node | ← → | Right/Left | | ||
| Expand Node | Double-Click on tag | Double-Click on tag | | ||
| Edit Attribute | ⏎ or Double-Click on attribute | Enter or Double-Click on attribute | | ||
|
||
### Styles Pane | ||
|
||
| | Mac | Windows / Linux | | ||
|-----------------------------------|----------------------------|-----------------| | ||
| Edit Rule | Double-Click | Double-Click | | ||
| Edit Next/Previous Property | ⇥ / ⇧⇥ | Tab/Shift-Tab | | ||
| Insert New Property | Double-Click on whitespace | Double-Click on whitespace | | ||
| Increment/Decrement Value | ⌥↑ /⌥ ↓ | Alt- Up/Alt-Down | | ||
| Increment/Decrement Value by 10 | ⌥⇧↑ / ⌥⇧↓ | Alt-Shift-Up/Alt-Shift-Down | | ||
| Increment/Decrement Value by 10 | ⌥PageUp / ⌥PageDown | Alt-PageUp/Alt-PageDown | | ||
| Increment/Decrement Value by 100 | ⌥⇧PageUp / ⌥⇧PageDown | Shift-PageUp/Shift-PageDown | | ||
| Increment/Decrement Value by 0.1 | ⌃⌥↑ / ⌃⌥↓ | Control-Alt-Up/Control-Alt-Down | | ||
|
||
### Debugger | ||
|
||
| | Mac | Windows / Linux | | ||
|-------------------------------|--------------|------------------| | ||
| Select Next Call Frame | ⌃. | Ctrl-. | | ||
| Select Previous Call Frame | ⌃, | Ctrl-, | | ||
| Continue | F8 or ⌘/ | F8 or Ctrl-/ | | ||
| Step Over | F10 or ⌘' | F10 or Ctrl-' | | ||
| Step Into | F11 or ⌘; | F11 or Ctrl-; | | ||
| Step Out | ⇧F11 or ⇧⌘; | Shift-F11 or Ctrl-Shift-; | | ||
| Evaluate Selection | ⇧⌘E | Ctrl-Shift-E | | ||
| Toggle Breakpoint Condition | Click on line number | Click on line number | | ||
| Edit Breakpoint Condition | Right-Click on line number | Right-Click on line number | | ||
|
||
|
||
## Using the Web Inspector remotely | ||
|
||
### Remote Web Inspector on GTK+ and EFL ports | ||
|
||
* For the GTK and EFL ports, this can be enabled with an environment variable. Check the documentation on EnvironmentVariables | ||
|
||
``` | ||
Computer1 # export WEBKIT_INSPECTOR_SERVER=${ip.ad.dre.ss}:${port} | ||
Computer1 # MiniBrowser http://google.com | ||
# | ||
Computer2 # MiniBrowser http://${ip.ad.dre.ss}:${port} | ||
``` | ||
|
||
* The very same version of WebKit has to be used on the other side | ||
|
||
### Apple Web Inspector Remote Experiment | ||
|
||
[Safari User Guide for Web Developers](http://developer.apple.com/safari/library/documentation/AppleApplications/Conceptual/Safari_Developer_Guide/UsingtheWebInspector/UsingtheWebInspector.html) | ||
In early 2010, an experiment was made to get Web Inspector to run in a plain old web page, debugging a remote web browsing session in another browser window. | ||
|
||
A write-up is available here: | ||
[weinre - Web Inspector Remote](http://muellerware.org/papers/weinre/manual.html), and the relevant source and demo archives are attached to this page. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
# Contributing to Web Inspector | ||
|
||
## Modifying the Web Inspector | ||
|
||
The Web Inspector user interface is implemented using JavaScript, CSS, and HTML. So, it's relatively easy to dig into the Web Inspector's sources and fix bugs or add new features. | ||
|
||
This wiki page documents the minimal steps required to modify styles used by the Web Inspector and submit your changes as a patch for review. | ||
|
||
Let's say, we don't like red color for CSS property names, and we would prefer property names to be purple instead. Let's get started! | ||
|
||
## Inspect The Inspector | ||
|
||
Since the Web Inspector UI is just another web page, we can inspect the Web Inspector with a second-level Web Inspector instance to quickly see what's going on. This requires a few magic settings to enable the "Inspect..." context menu on the Web Inspector window. | ||
|
||
For the Mac port, set the following defaults to allow inspecting the inspector. | ||
|
||
``` | ||
defaults write NSGlobalDomain WebKitDebugDeveloperExtrasEnabled -bool YES | ||
``` | ||
|
||
|
||
After updating these settings, run the [https://developer.apple.com/safari/technology-preview/ Safari Technology Preview]. Then, open the Web Inspector and right-click to inspect the inspector itself. | ||
|
||
By inspecting the CSS property names in the second-level inspector, we quickly find that the colors are defined by rules in `Source/WebInspectorUI/UserInterface/Views/SpreadsheetCSSStyleDeclarationEditor.css`. | ||
To create and submit a patch with our changes, we must to create an accompanying Bugzilla bug, and compute the diff of our changes against WebKit trunk. | ||
|
||
## Create / Update a Bug Report | ||
|
||
* [Existing Web Inspector Bugs](https://bugs.webkit.org/buglist.cgi?query_format=advanced&short_desc_type=allwordssubstr&short_desc=&component=Web+Inspector&long_desc_type=substring&long_desc=&bug_file_loc_type=allwordssubstr&bug_file_loc=&keywords_type=allwords&keywords=&bug_status=UNCONFIRMED&bug_status=NEW&bug_status=ASSIGNED&bug_status=REOPENED&emailassigned_to1=1&emailtype1=substring&email1=&emailassigned_to2=1&emailreporter2=1&emailcc2=1&emailtype2=substring&email2=&bugidtype=include&bug_id=&votes=&chfieldfrom=&chfieldto=Now&chfieldvalue=&cmdtype=doit&order=Reuse+same+sort+as+last+time&field0-0-0=noop&type0-0-0=noop&value0-0-0=) | ||
* [Create New Web Inspector Bug](http://webkit.org/new-inspector-bug) | ||
|
||
The WebKit project uses "bugs" in Bugzilla for fixes, new features, and any other code changes. Every commit must have an accompanying Bugzilla bug. | ||
|
||
So, the first step is to ensure that your proposed enhancement or fix has an associated bug. | ||
|
||
Once you find or create a bug report, make sure to add a comment stating your intent to work on the bug. | ||
This step is very important; comments on bugs in the Web Inspector Bugzilla component will automatically notify Web Inspector reviewers. | ||
|
||
This will allow them to answer any questions you may have about a proposed fix, and give feedback, pointers, and guidance for solving the issue. | ||
|
||
## Now Do Your Hacking | ||
|
||
1. [Get the Code](https://webkit.org/getting-the-code/) | ||
|
||
``` | ||
git clone https://github.com/WebKit/WebKit.git WebKit | ||
cd WebKit | ||
git checkout -b purple_css_values | ||
``` | ||
|
||
2. [Build WebKit](http://webkit.org/building/build.html) | ||
|
||
``` | ||
Tools/Scripts/build-webkit --release | ||
``` | ||
|
||
A clean build takes 20-80 minutes depending on the vintage of your machine. | ||
|
||
3. [Run it](http://webkit.org/building/run.html) | ||
|
||
``` | ||
Tools/Scripts/run-minibrowser --release | ||
``` | ||
|
||
4. Edit `Source/WebInspectorUI/UserInterface/Views/SpreadsheetCSSStyleDeclarationEditor.css` within the repo. | ||
|
||
5. Run `make -C Source/WebInspectorUI release` to copy files from `Source/WebInspectorUI/UserInterface` to the build directory. Do it after every time you modify Inspector's files. | ||
|
||
6. Look at your changes | ||
|
||
``` | ||
git status | ||
git diff Source/WebInspectorUI/ | ||
``` | ||
|
||
7. [Submit a PR](https://webkit.org/contributing-code/#overview) and wait for a review! | ||
|
||
``` | ||
git add -u | ||
git commit | ||
Tools/Scripts/git-webkit pull-request | ||
``` | ||
|
||
If you have any questions there are always people willing to help! Just jump onto [webkit.slack.com](https://webkit.slack.com), #webkit-inspector channel. |
22 changes: 22 additions & 0 deletions
22
docs/Deep Dive/Web Inspector/RemoteInspectorWebKitGTKandWPE.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
# Using the Remote Inspector with WebKitGTK+ and WPE | ||
|
||
The remote inspector enables debugging of web pages in environment where you might not be able to run the web inspector directly, such as WPE running in embedded targets. | ||
|
||
To run the remote inspector, you need to: | ||
|
||
- set the environment variable `WEBKIT_INSPECTOR_SERVER=ip:port` before running jsc or a browser/launcher powered by WPE or WebKitGTK+ | ||
- enable the WebKitSettings `enable-developer-extras` | ||
|
||
For example: | ||
|
||
``` | ||
export WEBKIT_INSPECTOR_SERVER=192.168.0.50:5000 | ||
MiniBrowser --enable-developer-extras=true https://wpewebkit.org | ||
``` | ||
|
||
Then, open another browser with the same version of WebKitGTK+ (matching the WPE version if it's the case) and open `inspector://ip:port`: | ||
|
||
|
||
``` | ||
MiniBrowser inspector://192.168.0.50:5000 | ||
``` |
Oops, something went wrong.