Bug 87045

Summary: [chromium] Build content_shell from within WebKit
Product: WebKit Reporter: jochen
Component: New BugsAssignee: jochen
Status: RESOLVED WONTFIX    
Severity: Normal CC: dglazkov, dpranke, eae, fishd, jam, leviw, peter, schenney, webkit.review.bot
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on: 91308    
Bug Blocks:    
Attachments:
Description Flags
Patch
none
Patch
none
Changes for Android
none
Adding Mac DEPS. none

jochen
Reported 2012-05-21 14:31:11 PDT
[chromium] Build content_shell from within WebKit
Attachments
Patch (3.54 KB, patch)
2012-05-21 14:31 PDT, jochen
no flags
Patch (3.59 KB, patch)
2012-07-23 03:53 PDT, jochen
no flags
Changes for Android (2.12 KB, text/plain)
2012-07-24 07:12 PDT, Peter Beverloo
no flags
Adding Mac DEPS. (4.11 KB, patch)
2012-10-30 09:17 PDT, Mike West
no flags
jochen
Comment 1 2012-05-21 14:31:44 PDT
jochen
Comment 2 2012-05-21 14:36:56 PDT
this is WIP patch for people that want to experiment with this. I tested this on Linux only The required chromium side is here: https://chromiumcodereview.appspot.com/10388218
Levi Weintraub
Comment 3 2012-05-21 14:38:35 PDT
(In reply to comment #2) > The required chromium side is here: https://chromiumcodereview.appspot.com/10388218 Is there anything stopping us from putting in the Chromium side? It doesn't actually change anything, no?
Levi Weintraub
Comment 4 2012-05-21 14:38:53 PDT
(In reply to comment #3) > Is there anything stopping us from putting in the Chromium side? It doesn't actually change anything, no? (I mean in the standard build case)
jochen
Comment 5 2012-05-21 14:41:05 PDT
(In reply to comment #4) > (In reply to comment #3) > > Is there anything stopping us from putting in the Chromium side? It doesn't actually change anything, no? > > (I mean in the standard build case) I just uploaded the CL, gimme a sec!
Levi Weintraub
Comment 6 2012-05-21 14:45:03 PDT
(In reply to comment #5) > (In reply to comment #4) > > (In reply to comment #3) > > > Is there anything stopping us from putting in the Chromium side? It doesn't actually change anything, no? > > > > (I mean in the standard build case) > > I just uploaded the CL, gimme a sec! Sorry, I wasn't trying to pressure you, just validating my understanding of that patch.
jochen
Comment 7 2012-05-21 15:05:25 PDT
here's the steps to build content_shell right now: 1) update-webkit --chromium 2) webkit-patch apply-attachment --no-clean --no-update 143098 3) cd Source/WebKit/chromium; gclient sync 4) curl -o - https://chromiumcodereview.appspot.com/download/issue10388218_4002.diff | patch -p1 5) python ./gyp_webkit 6) webkit-build --chromium --debug this should give you out/Debug/content_shell run with --dump-render-tree for a DRT like interface, or with --remote-debugging-port=9222 for devtools once the chromium side has landed, steps 4 and 5 are not required
WebKit Review Bot
Comment 8 2012-05-21 15:24:46 PDT
Comment on attachment 143098 [details] Patch Attachment 143098 [details] did not pass chromium-ews (chromium-xvfb): Output: http://queues.webkit.org/results/12740556
Darin Fisher (:fishd, Google)
Comment 9 2012-06-10 22:50:29 PDT
Comment on attachment 143098 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=143098&action=review > Source/WebKit/chromium/DEPS:142 > + 'third_party/flac': don't you think this file is getting out of control? the webkit repository shouldn't encode all of these details about what packages are required to build chromium. somehow we should extract that information from a file maintained in the chromium repository. webkit repository should just indicate the version of chromium and the location of the repository. problem: if the set of things chromium depends on changes, then you have to modify this file. the file listing the things chromium depends on should live in the chromium repository so that when those changes are made, they can be made as part of the same CL.
jochen
Comment 10 2012-06-10 23:31:10 PDT
It is already out of control... I think the right solution is that the.individual modules in chromium like webkit support or content should specify their own DEPS files instead of having this huge single DEPS in src/
Dirk Pranke
Comment 11 2012-06-13 12:50:16 PDT
Comment on attachment 143098 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=143098&action=review >> Source/WebKit/chromium/DEPS:142 >> + 'third_party/flac': > > don't you think this file is getting out of control? the webkit repository > shouldn't encode all of these details about what packages are required to > build chromium. somehow we should extract that information from a file > maintained in the chromium repository. webkit repository should just > indicate the version of chromium and the location of the repository. > > problem: if the set of things chromium depends on changes, then you have > to modify this file. the file listing the things chromium depends on > should live in the chromium repository so that when those changes are > made, they can be made as part of the same CL. as an alternative to multiple DEPS files in chrome, maybe we need to add some sort of wildcard or dependency or cascade feature into gclient, so you we could say something like 'content_deps': and have that get expanded to some list on the chromium-side ...
Darin Fisher (:fishd, Google)
Comment 12 2012-07-08 07:17:04 PDT
Yes, defining a variable like 'content_deps' on the chromium side that WebKit could use seems good. Jochen, the multiple DEPS file things suffers from diamond dependency problems. What happens if two modules don't agree on the version of 'net' or 'base' that they require? A single master list is simpler.
jochen
Comment 13 2012-07-23 03:53:25 PDT
Peter Beverloo
Comment 14 2012-07-24 07:12:50 PDT
Created attachment 154053 [details] Changes for Android Hi Jochen, I've attached the changes (to your patch) required to make this work for Android. At this moment we're not yet able to build content_shell itself. Instead, the content_shell_apk target will be sufficient for now, which right now wraps the Java files and creates an .apk. As work continues in bringing content_shell up on the Chromium side, dependencies will be added to the content_shell_apk target (i.e. one on content_shell itself). Concretely, this means that it won't work at all for Android :-). As development still is actively ongoing, I think it's best *not* to add a dependency on either content_shell or content_shell_apk for now when building for Android, mostly to avoid random build breakages after Chromium DEPS rolls. Once the work stabilizes and is closer to being finished, we can enable the dependency and make steps towards switching over. Adding the missing dependencies now should be fine, however.
jochen
Comment 15 2012-07-24 07:20:45 PDT
Thank you for the feedback. Right now, this bug is just for people that want to experiment with content shell in WebKit. I don't think it'll ever land, as webkit should not depend on content The plan is (roughly) to add methods to webkit_support for creating a webview that will either be created using TestShell or ContentShell
Mike West
Comment 16 2012-10-30 09:17:02 PDT
Created attachment 171464 [details] Adding Mac DEPS.
Note You need to log in before you can comment on or make changes to this bug.