Changes between Version 21 and Version 22 of BuildingCairoOnWindows
- Timestamp:
- Sep 18, 2018, 6:35:08 PM (7 years ago)
Legend:
- Unmodified
- Added
- Removed
- Modified
-
TabularUnified BuildingCairoOnWindows
v21 v22 1 1 [[PageOutline]] 2 2 3 WinCairo port is a WebKit port for Windows, which is fully OpenSouce and redistributable unlike AppleWin port, 4 It is using Cairo for the graphics backend, libcurl for the network backend. 5 3 6 = Building on Windows = 4 As with [wiki:"BuildingOnWindows" Apple's Windows Port], you must first follow the instructions on http://webkit.org/building/tools.html to install the necessary developer tools, support libraries, and check out the WebKit code.5 7 6 Note that it is safest to build WebKit in your Cygwin home directory (c:\cygwin\home\username\WebKit). At the moment, there seems to be an implicit assumption in the build scripts that paths will be relative to the home directory. 8 As with [wiki:"BuildingOnWindows" Apple's Windows Port], 9 you must first follow [https://webkit.org/webkit-on-windows/#installing-development-tools the instructions] to install the necessary developer tools, 10 and check out the WebKit code. 7 11 8 In the ~/WebKit/Tools/Scripts folder, use12 In the top source directory, use 9 13 {{{ 10 ./build-webkit --wincairo --release14 perl Tools/Scripts/build-webkit --wincairo --release 11 15 }}} 12 to start the build. Don't forget to add --release (or --debug), otherwise the --wincairo switch will be ignored.16 to start the build. 13 17 14 18 15 == Required Libraries == 16 You will need to obtain a set of build requirements that are analogous to the Apple port's WebKitAuxilliaryLibraries.zip. If you have a source tree newer than [http://trac.webkit.org/changeset/83657 r83657] you will get these libraries installed automatically when you perform a {{{update-webkit --wincairo}}} or a {{{build-webkit --wincairo}}}. These files are now part of the normal build path. 19 == Building from within Visual Studio == 17 20 18 == Building from within Visual Studio == 19 WebKit can be built from within Visual Studio by setting two environment variables: 20 * {{{WEBKIT_OUTPUTDIR}}} - An absolute Windows-style path pointing to the directory where you want the build products to go. 21 * {{{WEBKIT_LIBRARIES}}} - An absolute Windows-style path pointing to the WebKitLibraries/win folder in your WebKit checkout. 21 Some environmental variables should be propagated to Visual Studio. 22 22 23 == Common Build Errors ==24 === Error spawning cmd.exe ===25 Sometimes, Visual Studio complains that it 'cannot spawn cmd.exe'. Should this happen, check if both your `Cygwin\bin` folder and `c:\windows\sytem32` are both in the Visual Studio list of executable files (Tools -> Options -> VC++ Directories).26 27 === Bad line endings ===28 When you see errors in `WebCore/css/makeprops` or `WebCore/css/maketokenizer`, open those files in a suitable editor (SciTE works) and convert the line endings to LF only (Unix-style). You can also use the `dos2unix` command from the Cygwin shell. Then restart the build.29 30 === Missing Autogenerated Files ===31 If you have the Visual Studio IDE open while you are performing an {{{update-webkit}}}, you can sometimes run into a strange problem where Visual Studio is unable to locate the autogenerated files. These files are usually things like `HTMLNames.cpp`, which are generated by Perl as part of the WebCoreGenerated target.32 33 The best way to resolve this is to exit from the IDE, then relaunch. This usually fixes the problem, though you may wish to clean and rebuild the JavaScriptCoreGenerated and WebCoreGenerated projects.34 35 === Problems with Python auto-update ===36 You may encounter errors when the build environment attempts to install Python modules when running Cygwin in a Windows host OS inside a VMWare instance. The errors will look like the following:37 23 {{{ 38 webkitpy.common.system.autoinstall: INFO Auto-installing package: eliza.py 39 webkitpy.common.system.autoinstall: INFO From: "http://www.adambarth.com/webkit/eliza" 40 webkitpy.common.system.autoinstall: INFO To: "/cygdrive/e/Projects/WebKit/Tools/Scripts/webkitpy/thirdparty/autoinstalled/eliza.py" 41 Traceback (most recent call last): 42 File "/cygdrive/e/Projects/WebKit/Tools/Scripts/test-webkitpy", line 266, in <module> 43 Tester().run_tests(sys.argv, external_package_paths) 44 File "/cygdrive/e/Projects/WebKit/Tools/Scripts/webkitpy/test/main.py", line 1 24 perl WebKit/Tools/Scripts/build-webkit --wincairo --release --generate-project-only 25 set WEBKIT_LIBRARIES=%cd%\WebKitLibraries\win 26 set WEBKIT_OUTPUTDIR=%cd%\WebKitBuild 27 devenv WebKitBuild\Release\WebKit.sln 45 28 }}} 46 29 47 This seems to happen when running VMWare in NAT networking mode. If you switch to Bridged networking, everything should work properly.48 30 49 === Visual C++ Express Edition === 31 == Running the tests == 32 33 XAMPP should be installed in the default install path (c:\xampp). 34 Open a command prompt as administrator because http tests need to run Apache service. 35 50 36 {{{ 51 1>c:\cygwin\home\admin\webkit\javascriptcore\wtf\assertions.cpp(45) : fatal error C1083: Cannot open include file: 'windows.h': No such file or directory 37 set WEBKIT_LIBRARIES=%cd%\WebKitLibraries\win 38 set WEBKIT_OUTPUTDIR=%cd%\WebKitBuild 39 python Tools/Scripts/run-webkit-tests --release --wincairo --dump-render-tree 52 40 }}} 53 41 54 If you see errors like this you probably need to install the [http://msdn.microsoft.com/vstudio/express/visualc/usingpsdk/ platform SDK]. 42 You can use Docker to run LayoutTests by mounting the host directory. 55 43 56 == Running the tests == 57 After successfully building WebKit, in order to run the tests you need to: 58 1. copy the DLLs from `%WEBKIT_LIBRARIES%\bin32\` into your build output folder, otherwise {{{jsc}}} won't run properly. 59 1. Make sure the Cairo, JPEG, and PNG libraries are either in this directory, or in your PATH. 44 {{{ 45 docker run -it --rm --cpu-count=8 --memory=16g -v %cd%:c:\repo -w c:\repo webkitdev/msbuild 46 }}}