Bug 19867

Summary: Inspector should support $(id) in the command line
Product: WebKit Reporter: Keishi Hattori <keishi>
Component: Web Inspector (Deprecated)Assignee: Keishi Hattori <keishi>
Status: RESOLVED FIXED    
Severity: Enhancement CC: aroben, ggaren, rik, timothy
Priority: P2 Keywords: InRadar
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Bug Depends on:    
Bug Blocks: 14355    
Attachments:
Description Flags
patch
timothy: review-
test if "this" changes
none
patch timothy: review+

Keishi Hattori
Reported 2008-07-03 06:33:07 PDT
Inspector should support $(id) in the command line for Firebug parity.
Attachments
patch (2.15 KB, patch)
2008-07-07 06:03 PDT, Keishi Hattori
timothy: review-
test if "this" changes (140.78 KB, image/png)
2008-08-07 07:25 PDT, Keishi Hattori
no flags
patch (2.65 KB, patch)
2008-08-11 07:07 PDT, Keishi Hattori
timothy: review+
Keishi Hattori
Comment 1 2008-07-04 03:03:58 PDT
Putting the code below into Console._evalInInspectedWindow kind of works. I'll investigate a better way though. expression = "(function () { \ var $ = $ || function(id) { return document.getElementById(id); }; \ var $$ = $$ || function(cl) { return document.getElementsByClassName(cl); }; \ var $x = $x || function(xpath, context) { \ var nodes = []; \ try { \ var doc = context || document; \ var results = doc.evaluate(xpath, doc, null, XPathResult.ANY_TYPE, null); \ var node; \ while (node = results.iterateNext()) nodes.push(node); \ } catch (e) {} \ return nodes; \ }; \ var keys = keys || function(o) { var a = []; for (k in o) a.push(k); return a; }; \ var values = values || function(o) { var a = []; for (k in o) a.push(o[k]); return a; }; \ return (" + expression + ")})();";
Anthony Ricaud
Comment 2 2008-07-04 03:09:38 PDT
Just a comment about $$. It should be a wrapper for document.querySelectorAll instead of document.getElementsByClassName.
Keishi Hattori
Comment 3 2008-07-04 03:29:27 PDT
Sorry, thats a mistake.
Keishi Hattori
Comment 4 2008-07-04 07:15:08 PDT
I realized this is horribly wrong. I can't even do for loops.
Keishi Hattori
Comment 5 2008-07-07 06:03:35 PDT
Created attachment 22127 [details] patch I used "with" and it works fairly well.
Adam Roben (:aroben)
Comment 6 2008-07-10 08:12:22 PDT
Comment on attachment 22127 [details] patch + expression = "with (testAPI) { " + expression + " }"; I think using with like this will change the meaning of "this" in the user's expression. It should be pretty easy to test this. We definitely don't want to change "this"! It looks like Firebug uses window.__scope__, which I assume is a Mozilla-specific extension. Maybe Geoff Garen would have some ideas about how best to accomplish this.
Adam Roben (:aroben)
Comment 7 2008-07-11 14:06:30 PDT
Adam Roben (:aroben)
Comment 8 2008-08-07 07:23:41 PDT
(In reply to comment #6) > (From update of attachment 22127 [details] [edit]) > + expression = "with (testAPI) { " + expression + " }"; > > I think using with like this will change the meaning of "this" in the user's > expression. It should be pretty easy to test this. We definitely don't want to > change "this"! Keishi tells me that I was wrong and this approach does not modify the value of "this". That's great! Geoff, would you mind commenting on the approach here?
Adam Roben (:aroben)
Comment 9 2008-08-07 07:24:07 PDT
Comment on attachment 22127 [details] patch Putting back to r? and marking Geoff as a potential reviewer.
Keishi Hattori
Comment 10 2008-08-07 07:25:22 PDT
Created attachment 22695 [details] test if "this" changes I ran these commands in the command line and this is what I got. I don't think "this" changes. $("gbar"); $$("p"); $x("/html/body/div"); keys(console); values(console); window===this this
Timothy Hatcher
Comment 11 2008-08-07 09:05:08 PDT
Comment on attachment 22127 [details] patch You should rename testAPI to be more unique. Like __inspectorConsoleAPI. Also it might be better to explicitly assign __inspectorConsoleAPI t the window instead f using var. So: window. __inspectorConsoleAPI = ...
Keishi Hattori
Comment 12 2008-08-11 07:07:21 PDT
Created attachment 22727 [details] patch I've added profile/profileEnd but they don't work quite well. It picks up the anonymous function that it's wrapped with. Also the result doesn't get updated. Maybe profile not getting updated should be a bug on it's own.
Timothy Hatcher
Comment 13 2008-08-11 20:40:10 PDT
Comment on attachment 22727 [details] patch + if (!inspectedWindow._inspectorCommandLineAPI) You should put braces around that if block, since it is multiple lines. Also you should improve the ChangeLog to call out what functions you are changing and add more description before the Reviewed by line. The < > and commas aren't needed for the bug list. Just put one per line. Please file a bug about the profiler issues you mentioned.
Timothy Hatcher
Comment 14 2008-08-11 20:58:02 PDT
Landed in r35676.
Note You need to log in before you can comment on or make changes to this bug.