Bug 20046

Summary: compile mismatch Cg/Cairo files (SVN 35180)
Product: WebKit Reporter: Samuele Catuzzi <samuele_catuzzi>
Component: SVGAssignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: bfulgham
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: PC   
OS: Windows XP   
Attachments:
Description Flags
Extend default configuration handler to deal with Cairo case. none

Samuele Catuzzi
Reported 2008-07-15 15:25:32 PDT
in order to compile --cairo-win32 I modified config.h as this: #if PLATFORM(WIN) #define WTF_USE_JAVASCRIPTCORE_BINDINGS 1 #undef WTF_PLATFORM_CG #define WTF_PLATFORM_CAIRO 1 #define WTF_USE_CFNETWORK 1 #undef WTF_USE_WININET #define WTF_PLATFORM_CF 1 #define WTF_USE_PTHREADS 0 #endif from WebCore compilation I receive several errors from "WebCore/Release/BuildLog.htm" that start with: ---snip---- SVGResourceMaskerCg.cpp SVGResourceFilterCg.cpp SVGResourceClipperCg.cpp ..\svg\graphics\cg\SVGResourceClipperCg.cpp(40) : error C2440: 'initializing' : cannot convert from 'PlatformGraphicsContext *' to 'CGContextRef' Types pointed to are unrelated; conversion requires reinterpret_cast, C-style cast or function-style cast ---snip---- I found that WebCore.vcproj around line 15692 has this dependency: <File RelativePath="..\svg\graphics\cg\SVGResourceClipperCg.cpp" > <FileConfiguration Name="Debug_Cairo|Win32" ExcludedFromBuild="true" > <Tool Name="VCCLCompilerTool" /> </FileConfiguration> <FileConfiguration Name="Release_Cairo|Win32" ExcludedFromBuild="true" > <Tool Name="VCCLCompilerTool" /> </FileConfiguration> </File> but Cairo files are located in "..\svg\graphics\cairo\" directory and correct SVGResourceClipper file name should be "SVGResourceClipperCairo.cpp" thus: <File RelativePath="..\svg\graphics\cairo\SVGResourceClipperCairo.cpp" > this error appear replicated on my "WebCore/Release/BuildLog.htm" for every file located into "..\svg\graphics\cg\" directory. good work!
Attachments
Extend default configuration handler to deal with Cairo case. (2.61 KB, patch)
2008-07-17 11:22 PDT, Brent Fulgham
no flags
Mark Rowe (bdash)
Comment 1 2008-07-15 17:56:19 PDT
You'll notice from the quoted snippet of the project file that the CG files are set to be excluded from the build when the configuration Debug_Cairo or Release_Cairo is used. Are you building with one of those configurations?
Samuele Catuzzi
Comment 2 2008-07-15 19:00:01 PDT
(In reply to comment #1) > You'll notice from the quoted snippet of the project file that the CG files are > set to be excluded from the build when the configuration Debug_Cairo or > Release_Cairo is used. Are you building with one of those configurations? > I simple compiled it with: WebKit/webKitTools/Scripts/build-webkit --cairo-win32 if I try to use set-webkit-configuration with release or debug those errors remain. Also as test, I tried to compile all sources without modify config.h and all worked fine but obviusually that was not a cairo build. * before every new compilation I cleaned WebKitBuild directory
Mark Rowe (bdash)
Comment 3 2008-07-15 21:05:51 PDT
Which configuration does the build transcript show that it is building? Does it mention Debug, Release, Debug_Cairo, or Release_Cairo in the output?
Brent Fulgham
Comment 4 2008-07-15 21:33:26 PDT
(In reply to comment #3) > Which configuration does the build transcript show that it is building? Does > it mention Debug, Release, Debug_Cairo, or Release_Cairo in the output? > This is my fault. It looks like it only works properly if you use the "--debug" or "--release" flags in conjunction with the "--cairo-win32". I'll correct the build script to handle this properly.
Brent Fulgham
Comment 5 2008-07-15 21:38:39 PDT
(In reply to comment #4) > This is my fault. It looks like it only works properly if you use the > "--debug" or "--release" flags in conjunction with the "--cairo-win32". I'll > correct the build script to handle this properly. Just to clarify: If you use the command line: "build-webkit --release --cairo-win32", you get the correct "Release_Cairo" target. Likewise, if you use "build-webkit --debug --cairo-win32", you get the correct "Debug_Cairo" target. If you don't supply the --release/--debug argument, the script eventually falls back to Release, which then builds the wrong stuff for a Cairo build. This is why things work properly when you change the defines in the "config.h" file.
Samuele Catuzzi
Comment 6 2008-07-16 09:51:56 PDT
(In reply to comment #5) in SVN 35180 If I try: WebKit/webKitTools/Scripts/build-webkit --release --cairo-win32 it require "qmake" command, the qmake into cygwin installation not work becouse it is an old one (qt3) so I installed newer "qt-win-opensource-4.4.0-mingw.exe" from trolltech site and than added "C:\Qt\4.4.0\bin" into my path. Now (even with svn35180) after "build-webkit --release --cairo-win32" the script say: *********start************ Subroutine main::tmpnam redefined at /home/admin/WebKit/WebKitTools/Scripts/webkitdirs.pm line 33 Subroutine main::tmpfile redefined at /home/admin/WebKit/WebKitTools/Scripts/webkitdirs.pm line 33 Checking mod-date of WebKitSupportLibrary.zip... Current WebKitSupportLibrary is up to date Calling 'qmake CONFIG+=qt-port -r OUTPUT_DIR=/home/admin/WebKit/WebKitBuild/Release_Cairo /home/admin/WebKit/WebKit.pro CONFIG+=release CONFIG-=debug' in /home/admin/WebKit/WebKitBuild/Release_Cairo Cannot find file: \home\admin\WebKit\WebKit.pro. Failed to setup build environment using qmake! **********end*********** But the file "WebKit.pro" is /home/admin/WebKit/WebKit.pro under windows it reside here C:\cygwin\home\admin\WebKit\WebKit.pro so I have found another problem :-)
Brent Fulgham
Comment 7 2008-07-16 12:55:48 PDT
(In reply to comment #6) > it require "qmake" command, the qmake into cygwin installation not work becouse > it is an old one (qt3) so I installed newer "qt-win-opensource-4.4.0-mingw.exe" > from trolltech site and than added "C:\Qt\4.4.0\bin" into my path. > Now (even with svn35180) after "build-webkit --release --cairo-win32" the > script say: If you are being required to use qmake, something is terribly wrong. Neither the CG nor the Cairo builds require QMake for anything.
Samuele Catuzzi
Comment 8 2008-07-16 15:29:58 PDT
(In reply to comment #7) > > If you are being required to use qmake, something is terribly wrong. Neither > the CG nor the Cairo builds require QMake for anything. > (even in 35180) If I remove "C:\Qt\4.4.0\bin" from my PATH the script say: $ WebKit/webKitTools/Scripts/build-webkit --release --cairo-win32 Subroutine main::tmpnam redefined at /home/admin/WebKit/WebKitTools/Scripts/webkitdirs.pm line 33 Subroutine main::tmpfile redefined at /home/admin/WebKit/WebKitTools/Scripts/webkitdirs.pm line 33 Checking mod-date of WebKitSupportLibrary.zip... Current WebKitSupportLibrary is up to date Can't exec "qmake": No such file or directory at /home/admin/WebKit/WebKitTools/Scripts/webkitdirs.pm line 736. Use of uninitialized value $mkspec in scalar chomp at /home/admin/WebKit/WebKitTools/Scripts/webkitdirs.pm line 736. Calling 'qmake CONFIG+=qt-port -r OUTPUT_DIR=/home/admin/WebKit/WebKitBuild/Release_Cairo /home/admin/WebKit/WebKit.pro CONFIG+=release CONFIG-=debug' in /home/admin/WebKit/WebKitBuild/Release_Cairo Can't exec "qmake": No such file or directory at /home/admin/WebKit/WebKitTools/Scripts/webkitdirs.pm line 856. Failed to setup build environment using qmake!
Samuele Catuzzi
Comment 9 2008-07-16 19:26:18 PDT
(In reply to comment #8) for now, I found a solution of the "qmake" problem: If in your cygwin installation you have qt3* packages than when you try to build webkit for some obscure reasons it ask to you "qmake" command. To solve this problem simply run setup of cygwin and remove all qt3 packages, than run again Cygwin bash console and your problem disappear. I think that someone should update the http://trac.webkit.org/wiki/BuildingCairoOnWindows becouse at least config.h is changed
Brent Fulgham
Comment 10 2008-07-17 11:22:27 PDT
Created attachment 22342 [details] Extend default configuration handler to deal with Cairo case.
Mark Rowe (bdash)
Comment 11 2008-07-23 16:42:07 PDT
Comment on attachment 22342 [details] Extend default configuration handler to deal with Cairo case. Clearing the review flag as the bug is closed.
Note You need to log in before you can comment on or make changes to this bug.