WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
133785
Fix build break on EFL port since
r169869
https://bugs.webkit.org/show_bug.cgi?id=133785
Summary
Fix build break on EFL port since r169869
Gyuyoung Kim
Reported
2014-06-11 22:22:57 PDT
There is build error since rr169869. In file included from /mnt/buildbot/WebKit-BuildSlave/efl-linux-64-release-wk2/build/Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundleAPICast.h:31:0, from /mnt/buildbot/WebKit-BuildSlave/efl-linux-64-release-wk2/build/Source/WebKit2/WebProcess/InjectedBundle/InjectedBundle.cpp:36: /mnt/buildbot/WebKit-BuildSlave/efl-linux-64-release-wk2/build/Source/WebKit2/WebProcess/InjectedBundle/API/c/WKBundlePagePrivate.h:96:5: error: "TARGET_OS_IPHONE" is not defined [-Werror=undef] #if TARGET_OS_IPHONE ^
Attachments
Patch
(2.38 KB, patch)
2014-06-11 22:24 PDT
,
Gyuyoung Kim
no flags
Details
Formatted Diff
Diff
View All
Add attachment
proposed patch, testcase, etc.
Gyuyoung Kim
Comment 1
2014-06-11 22:24:23 PDT
Created
attachment 232931
[details]
Patch
Csaba Osztrogonác
Comment 2
2014-06-11 22:46:33 PDT
Comment on
attachment 232931
[details]
Patch Clearing flags on attachment: 232931 Committed
r169879
: <
http://trac.webkit.org/changeset/169879
>
Csaba Osztrogonác
Comment 3
2014-06-11 22:46:41 PDT
All reviewed patches have been landed. Closing bug.
Simon Fraser (smfr)
Comment 4
2014-06-11 23:13:09 PDT
Sorry for the breakage.
Csaba Osztrogonác
Comment 5
2014-06-11 23:14:49 PDT
(In reply to
comment #4
)
> Sorry for the breakage.
Not problem, unfortunately this fix broke Mac, but I'll land the proper fix immediately.
Csaba Osztrogonác
Comment 6
2014-06-11 23:19:01 PDT
Fix landed in
https://trac.webkit.org/changeset/169880
Andy Estes
Comment 7
2014-06-11 23:53:26 PDT
Why not just do this: #if defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE On Apple platforms, TARGET_OS_IPHONE is always defined, it's just set to 0 on the Mac. Also, in the .cpp file you can just use PLATFORM(IOS). TARGET_OS_IPHONE is only necessary in API headers.
Csaba Osztrogonác
Comment 8
2014-06-11 23:56:41 PDT
(In reply to
comment #7
)
> Why not just do this: > #if defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE
It was the first idea, but unfortunately GCC's preprocessor doesn't do short circuit macro evaluation, and the build fails when it tries to evaluate the non defined right side of &&.
Andy Estes
Comment 9
2014-06-11 23:58:20 PDT
> It was the first idea, but unfortunately GCC's preprocessor doesn't do short circuit macro evaluation
I didn't know that! Thanks for the explanation.
Alexey Proskuryakov
Comment 10
2014-06-12 09:41:37 PDT
This fix broke Mac port, fixed in
r169900
.
> It was the first idea, but unfortunately GCC's preprocessor doesn't do short circuit macro evaluation
This is very surprising, because we've always used this technique, even before switching to clang.
> Fix landed in
https://trac.webkit.org/changeset/169880
This patch had [EFL][GTK] in its title despite touching cross-platform files. This confused me for a moment. These bracketed prefixes are intended for bugs and patches that don't touch cross-platform code at all, making them of zero interest to people who don't work on the particular platform. For example, adding code in an #if doesn't qualify, because it could be introducing a design problem that will make refactoring cross-platorfm code harder.
Csaba Osztrogonác
Comment 11
2014-06-13 01:05:16 PDT
(In reply to
comment #10
)
> This fix broke Mac port, fixed in
r169900
.
Sorry for the breakage, unfortunately we haven't noticed it. +1 for having a buildstep for this and having style checker against c++ style comments in Platform.h (
Bug133802
)
> > It was the first idea, but unfortunately GCC's preprocessor doesn't do short circuit macro evaluation > > This is very surprising, because we've always used this technique, even before switching to clang.
After checking it in details, you are true. In this case the short circuit evaluation really works fine with all of my installed GCC version. I confused because of a similar problem, where it doesn't work at all: test.cpp:5:45: error: missing binary operator before token "(" #if defined(__has_include) && __has_include(<stdio.h>) ^ Here only nested ifs help for GCC users.
> This patch had [EFL][GTK] in its title despite touching cross-platform files. This confused me for a moment. > > These bracketed prefixes are intended for bugs and patches that don't touch cross-platform code at all, making them of zero interest to people who don't work on the particular platform. For example, adding code in an #if doesn't qualify, because it could be introducing a design problem that will make refactoring cross-platorfm code harder.
It's new for me, as far as I remember everybody use [GTK]/[EFL]/[Mac]/[iOS]/[iOS][WK2] title prefix for bugs which touches cross platform files, but surely (or likely) has no effect for other platforms. I remember many [iOS] and [Mac] prefixed bug which touched cross platform code and broke other platform. I'm not against the rule you mentioned, it could help us.
Csaba Osztrogonác
Comment 12
2014-06-13 01:16:06 PDT
Let's go back to the original problem for a minute. The problem was adding new "#if TARGET_OS_IPHONE" guards which caused undef warning(=error). I don't want to expect using "#if defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE" always in the future. I'm pretty sure if folks will forget it sometimes and will break the GCC builds accidentally again and again. That's why I added the false definition for TARGET_OS_IPHONE on EFL and GTK. If you don't have objection, I would add back a c style comment to Platform.h like: /* To avoid possible build breakages because of undefined TARGET_OS_IPHONE */
Andy Estes
Comment 13
2014-06-13 12:43:51 PDT
(In reply to
comment #12
)
> Let's go back to the original problem for a minute. The problem was adding > new "#if TARGET_OS_IPHONE" guards which caused undef warning(=error). I > don't want to expect using "#if defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE" > always in the future. I'm pretty sure if folks will forget it sometimes and > will break the GCC builds accidentally again and again.
I don't think this situation will arise very often. We only use TARGET_OS_IPHONE in API headers since those headers are included in translation units that don't use our prefix header. In all other places, we'll use PLATFORM(IOS). Further, only a subset of our API headers are cross-platform (e.g. the Cocoa API headers are only used on Apple platforms), and API headers don't tend to change as often as other files in the project.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug