Bug 184166

Summary: Xcode prepends line comments from WTF/Compiler.h to *.sb files
Product: WebKit Reporter: Ross Kirsling <ross.kirsling>
Component: Web Template FrameworkAssignee: Ross Kirsling <ross.kirsling>
Status: RESOLVED FIXED    
Severity: Normal CC: ap, bfulgham, commit-queue, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=184062
Attachments:
Description Flags
Patch none

Ross Kirsling
Reported 2018-03-29 17:46:06 PDT
Repro: 1. Add a line comment (// not /* */) to the start of a line in this file: https://github.com/WebKit/webkit/blob/master/Source/WTF/wtf/Compiler.h 2. Open Xcode and hit the Play button => WebContent process crashes immediately Cause: The comment gets prepended to this file, in which C-style comments are invalid: /Users/.../Library/Developer/Xcode/DerivedData/WebKit-.../Build/Products/Debug/WebKit.framework/Resources/com.apple.WebProcess.sb (It will also be prepended to com.apple.WebKit.NetworkProcess.sb and com.apple.WebKit.Storage.sb in the same directory.) This file originates here: https://github.com/WebKit/webkit/blob/master/Source/WebKit/WebProcess/com.apple.WebProcess.sb.in It appears to be processed by this script: https://github.com/WebKit/webkit/blob/master/Source/WebKit/DerivedSources.make Reason for concern: This issue is very time-consuming to debug for the following reasons. - It is completely unexpected, as C, C++, and ObjC all support line comments. - The issue only occurs from the Xcode UI and not from the `build-webkit` CLI. - Selecting Product > Clean in Xcode is not a fix -- one must actually delete the DerivedData subdirectory (the existence of which is hardly common knowledge!).
Attachments
Patch (2.09 KB, patch)
2018-03-30 11:01 PDT, Ross Kirsling
no flags
Alexey Proskuryakov
Comment 1 2018-03-29 20:42:08 PDT
The fix would be two-fold: 1. Add a script step to remove comment lines from processed profiles. 2. Change preprocessor mode to C++.
Ross Kirsling
Comment 2 2018-03-29 20:50:26 PDT
(In reply to Alexey Proskuryakov from comment #1) > The fix would be two-fold: > > 1. Add a script step to remove comment lines from processed profiles. > 2. Change preprocessor mode to C++. Looks like both parts might be doable all in one step here: https://github.com/WebKit/webkit/blob/master/Source/WebKit/DerivedSources.make#L220-L227 I wonder if it's safe to replace all of the above with the following? > TEXT_PREPROCESSOR_FLAGS=-E -P -x -w
Ross Kirsling
Comment 3 2018-03-29 20:53:01 PDT
(In reply to Ross Kirsling from comment #2) > I wonder if it's safe to replace all of the above with the following? > > TEXT_PREPROCESSOR_FLAGS=-E -P -x -w Sorry, that should have been: > TEXT_PREPROCESSOR_FLAGS=-E -P -w
Alexey Proskuryakov
Comment 4 2018-03-29 21:01:16 PDT
The C++ preprocessor would result in breaking comments that contain URLs, so a step to remove semicolon based comments is necessary. This is all of course based on an assumption that we will never have two slashes in an actual sandbox rule. I think that it’s an ok assumption to make.
Ross Kirsling
Comment 5 2018-03-29 21:09:09 PDT
(In reply to Alexey Proskuryakov from comment #4) > The C++ preprocessor would result in breaking comments that contain URLs, so > a step to remove semicolon based comments is necessary. > > This is all of course based on an assumption that we will never have two > slashes in an actual sandbox rule. I think that it’s an ok assumption to > make. That makes sense. I just discovered your original motivation in https://bugs.webkit.org/show_bug.cgi?id=83827. :)
Ross Kirsling
Comment 6 2018-03-30 11:01:34 PDT
Alexey Proskuryakov
Comment 7 2018-03-31 23:03:08 PDT
*** Bug 181309 has been marked as a duplicate of this bug. ***
Ross Kirsling
Comment 8 2018-04-03 10:48:31 PDT
I believe this patch satisfies the desired criteria. It is naive in indiscriminately treating semicolons as comment-openers in *.sb.in files, but it's a simple fix that's compatible with the way those files are currently used.
Brent Fulgham
Comment 9 2018-04-03 10:50:07 PDT
Comment on attachment 336872 [details] Patch Looks good. r=me.
WebKit Commit Bot
Comment 10 2018-04-03 11:15:00 PDT
Comment on attachment 336872 [details] Patch Clearing flags on attachment: 336872 Committed r230213: <https://trac.webkit.org/changeset/230213>
WebKit Commit Bot
Comment 11 2018-04-03 11:15:02 PDT
All reviewed patches have been landed. Closing bug.
Radar WebKit Bug Importer
Comment 12 2018-04-03 11:19:03 PDT
Note You need to log in before you can comment on or make changes to this bug.