gtk2/build/win32/vs9
Chun-wei Fan 09b7dc81a6 build: Integrate introspection builds into MSVC projects
This is so that it is easier for one building GTK+ with Visual Studio to
build the introspection files as well in one shot.  Note that this is
not built by default, so one needs to select the gtk3-introspect
explicitly to build (and clean up) the introspection files.

For this to work, one needs to ensure the following:
-A complete build of GObject-Introspection in $(GlibEtcInstallRoot),
 that is built with the same installation of the Python interpretor that
 is used here (see PythonDir and PythonDirX64 in
 gtk3-version-paths.[vsprops|props]).
-Introspection files for ATK, GDK-Pixbuf and Pango, also in their proper
 locations under $(GlibEtcInstallRoot), which should be built with the
 same G-I installation.
2017-08-28 16:18:24 +08:00
..
broadwayd.vcprojin MSVC Builds: Update Project GUIDs 2015-09-21 16:50:00 +08:00
gailutil-3.vcprojin MSVC Builds: Update Project GUIDs 2015-09-21 16:50:00 +08:00
gdk3-broadway.vcprojin MSVC Builds: Update Project GUIDs 2015-09-21 16:50:00 +08:00
gdk3-win32.vcprojin MSVC Builds: Update Project GUIDs 2015-09-21 16:50:00 +08:00
gdk-3.vcprojin Visual Studio builds: Clean up projects a bit 2016-05-09 15:35:26 +08:00
gtk3-build-defines.vsprops build: Integrate introspection builds into MSVC projects 2017-08-28 16:18:24 +08:00
gtk3-copy-gdk-broadway.vsprops Visual Studio builds: Fix Broadway builds 2016-11-16 11:50:32 +08:00
gtk3-demo-application.vcprojin MSVC builds: Use /opt:ref for release builds 2015-11-12 18:16:33 +08:00
gtk3-demo.vcprojin MSVC builds: Use /opt:ref for release builds 2015-11-12 18:16:33 +08:00
gtk3-gen-srcs.vsprops build: Use PythonDir in Visual Studio projects 2017-08-28 15:55:59 +08:00
gtk3-icon-browser.vcprojin MSVC builds: Use /opt:ref for release builds 2015-11-12 18:16:33 +08:00
gtk3-ignore-broadway.vsprops MSVC Builds: Massive Rename of Projects 2015-09-15 18:51:33 +08:00
gtk3-install.vcproj Visual Studio builds: Refine "installation" process 2016-05-10 13:18:23 +08:00
gtk3-install.vspropsin build: Use PythonDir in Visual Studio projects 2017-08-28 15:55:59 +08:00
gtk3-introspect.vcproj build: Integrate introspection builds into MSVC projects 2017-08-28 16:18:24 +08:00
gtk3-prebuild.vcproj MSVC Builds: Update Project GUIDs 2015-09-21 16:50:00 +08:00
gtk3-version-paths.vsprops.in build: Integrate introspection builds into MSVC projects 2017-08-28 16:18:24 +08:00
gtk-3.vcprojin Visual Studio builds: Clean up projects a bit 2016-05-09 15:35:26 +08:00
gtk-builder-tool.vcproj MSVC builds: Build more tools in gtk/ 2015-12-15 15:37:33 +08:00
gtk-encode-symbolic-svg.vcproj MSVC Builds: Update Project GUIDs 2015-09-21 16:50:00 +08:00
gtk-query-settings.vcproj MSVC builds: Build more tools in gtk/ 2015-12-15 15:37:33 +08:00
gtk-update-icon-cache.vcproj MSVC builds: Build more tools in gtk/ 2015-12-15 15:37:33 +08:00
gtk+.sln build: Integrate introspection builds into MSVC projects 2017-08-28 16:18:24 +08:00
Makefile.am build: Integrate introspection builds into MSVC projects 2017-08-28 16:18:24 +08:00
README.txt build: Integrate introspection builds into MSVC projects 2017-08-28 16:18:24 +08:00

Please do not compile this package (GTK+) in paths that contain
spaces in them-as strange problems may occur during compilation or during
the use of the library.

A more detailed outline for instructions on building the GTK+ with Visual
C++ can be found in the following GNOME Live! page:

https://wiki.gnome.org/Projects/GTK+/Win32/MSVCCompilationOfGTKStack

This VS9 solution and the projects it includes are intented to be used
in a GTK+ source tree unpacked from a tarball. In a git checkout you
first need to use some Unix-like environment or manual work to expand
the files needed, like config.h.win32.in into config.h.win32 and the
.vcprojin files here into corresponding actual .vcproj files.

You will need the parts from below in the GTK+ stack: GDK-Pixbuf, Pango,
ATK and GLib.  External dependencies are at least Cairo
(with Cairo-GObject support, meaning Cairo 1.10.x or later), zlib, libpng,
gettext-runtime, fontconfig*, freetype*, expat*.  See the 
build/win32/vs9/README.txt file in glib for details where to unpack them.

You will also need a Python 2.6+/3.x interpretor installed on your system,
which can be obtained from the official installers available from
http://www.python.org.  Please note that the Python interpretor (python.exe)
either needs to be in your PATH before attempting the build of GTK+, or it
can be found in the path specified by PythonDir in gtk-version-paths.vsprops.
If you happen to change the PythonDir setting in gtk-version-paths.vsprops after
opening gtk+.sln with Visual Studio, you will need to close the gtk+.sln solution,
delete all the *.ncb, *.suo and *.user files before re-attempting the build.

It is recommended that one builds the dependencies with VS9 as far as
possible, especially those from and using the GTK+ stack (i.e. GLib,
Cairo, ATK, Pango, GDK-Pixbuf), so that crashes caused by mixing calls
to different CRTs can be kept at a minimum.  

zlib, libpng, and Cairo do contain support for compiling under VS9
using VS project files and/or makefiles at this time of writing, For the
GTK+ stack, VS9 project files are either available under
$(srcroot)/build/vs9 in the case of GLib (stable/unstable), ATK
(stable/unstable) and GDK-Pixbuf (unstable), and should be in the next
unstable version of Pango.  There is no known official VS9 build
support for fontconfig (along with freetype and expat) and
gettext-runtime, so please use the binaries from: 

ftp://ftp.gnome.org/pub/GNOME/binaries/win32/dependencies/ (32 bit)
ftp://ftp.gnome.org/pub/GNOME/binaries/win64/dependencies/ (64 bit)

Unzip the binaries obtained from ftp.gnome.org in <root>\vs9\<PlatformName>,
and build the following, if not already done so: 

Note: put the resulting zlib, libpng, pcre and Cairo files as follows:
 .dll files: <root>\vs9\<PlatformName>\bin
 .lib files: <root>\vs9\<PlatformName>\lib
 .h files: <root>\vs9\<PlatformName>\include

The recommended build order for these dependencies:
(first unzip any dependent binaries downloaded from the ftp.gnome.org
 as described in the README.txt file in the build/win32/vs9 folder)
-zlib
-libpng
-(for GDK-Pixbuf, if not using GDI+) IJG JPEG or libjpeg-turbo
-(for GDK-Pixbuf, if not using GDI+) libtiff
 [libtiff requires zlib and IJG JPEG or libjpeg-turbo]
-(for GDK-Pixbuf, if not using GDI+) jasper [jpeg-2000 library])
-(optional for GLib) PCRE (version 8.12 or later, use of CMake to
  build PCRE is recommended-see build/win32/vs9/README.txt of GLib)
-GLib **
-Cairo (inclusive of Cairo-GObject)
-ATK**
-Pango**
-GDK-Pixbuf**
(note the last 3 dependencies are not interdependent, so the last 3
 dependencies can be built in any order)

The "install" project will copy build results and headers into their
appropriate location under <root>\vs9\<PlatformName>. For instance,
built DLLs go into <root>\vs9\<PlatformName>\bin, built LIBs into
<root>\vs9\<PlatformName>\lib and GTK+ headers into
<root>\vs9\<PlatformName>\include\gtk-3.0. This is then from where
project files higher in the stack are supposed to look for them, not
from a specific GLib source tree.

There is now a "gtk3-introspect" project that is used to build the
introspection files.  In order for this to work, check that the paths for
PythonDir (32-bit builds) and PythonDirX64 (x64 builds) are correct for your
system.  Note that it must be the same Python installation that was used to
build GObject-Introspection (G-I), and a complete G-I build/installation
needs to be found in <root>\vs9\<PlatformName>\, with the introspection files
for ATK, Pango and GDK-Pixbuf.  Note also that this is not built by default,
so you will need to right-click on the project to build it, which will build
and "install" the other projects that are normally built, if those were not yet
built.  The introspection files that are built will be "installed" to
<root>\vs9\<PlatformName>\share\gir-1.0 (the .gir file(s)) and
<root>\vs9\<PlatformName>\lib\girepository-1.0 (the .typelib files(s)) upon
successful build.  for building this in a different configuration, therefore,
you will need to clean this project specifically and then rebuild.

Please note, as GTK+ uses the Adwaita theme for all platforms by default,
most icons used are not included with GTK+ (which *are* needed), so please see
https://live.gnome.org/GTK%2B/Win32/MSVCCompilationOfGTKStack (under the
GTK+ section) on how to get those icons set up for use with GTK+.

*About the dependencies marked with *: These dependencies are optional
 as those are not compulsory components for building and running GTK+
 itself, but note that they are needed for people running and building
 GIMP or those who need complex script support via fontconfig.  They
 are referred to by components in Cairo and Pango mainly.
 Decide whether you need fontconfig support prior to building Cairo
 and Pango.

**:Put the sources of the packages marked with ** in <root>\<package-
    source-tree>, and build with VS9 from there.

--Tor Lillqvist <tml@iki.fi>
--Updated by Chun-wei Fan <fanc999@yahoo.com.tw>