gtk2/build/win32/vs10
Chun-wei Fan 801a7ca17f Visual Studio Builds: Support Building Introspection Files
Add Windows .bat and Python script to call g-ir-scanner to build
introspection files for Visual Studio builds.  This will read from the
autotools files using Python REGEX functionality to determine the headers
and sources for g-ir-scanner to process, so the autotools files will not
need to be updated except to distribute the necessary files.  Thils will
also enable one to build introspection files on Windows without using a
BASH-style shell such as MSYS.

Also add an utility Visual Studio project to call the Windows .bat to
build the introspection files for GTK+/GDK, for convenience.
2013-03-06 13:12:01 +08:00
..
gailutil.vcxproj Re-organize Visual Studio property sheets a bit 2013-02-22 13:13:54 +08:00
gailutil.vcxproj.filters Added VS projects for a11y and libgail-util 2011-07-14 11:53:36 +08:00
gdk-win32.vcxproj Prepare Visual Studio 2010 projects for Visual Studio 2012 2013-01-23 14:03:30 +08:00
gdk-win32.vcxproj.filters Update gdk-win32 Visual C++ projects 2012-04-06 00:24:34 +08:00
gdk.vcxproj.filtersin
gdk.vcxprojin Re-organize Visual Studio property sheets a bit 2013-02-22 13:13:54 +08:00
gengir.vcxproj Visual Studio Builds: Support Building Introspection Files 2013-03-06 13:12:01 +08:00
gtk3-demo-application.vcxproj Fix gtk3-demo Visual Studio projects 2013-02-27 12:33:42 +08:00
gtk3-demo-application.vcxproj.filters Add Visual Studio project for gtk3-demo-application 2013-02-22 13:09:50 +08:00
gtk3-demo.vcxproj Fix gtk3-demo Visual Studio projects 2013-02-27 12:33:42 +08:00
gtk3-demo.vcxproj.filters Fix gtk-demo projects 2013-02-21 15:30:41 +08:00
gtk.vcxproj.filtersin
gtk.vcxprojin Re-organize Visual Studio property sheets a bit 2013-02-22 13:13:54 +08:00
gtk+.props Re-organize Visual Studio property sheets a bit 2013-02-22 13:13:54 +08:00
gtk+.sln Add Visual Studio project for gtk3-demo-application 2013-02-22 13:09:50 +08:00
gtka11y.vcxproj.filtersin Redo Completion of Visual Studio projects for gtka11y 2013-02-21 15:48:04 +08:00
gtka11y.vcxprojin Redo Completion of Visual Studio projects for gtka11y 2013-02-21 15:48:04 +08:00
install.vcxproj Add Visual Studio project for gtk3-demo-application 2013-02-22 13:09:50 +08:00
Makefile.am Visual Studio Builds: Support Building Introspection Files 2013-03-06 13:12:01 +08:00
README.txt Update README.win32 and Visual C++ Readme.txt's 2011-08-31 14:28:47 +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://live.gnome.org/GTK%2B/Win32/MSVCCompilationOfGTKStack

This VS10 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
.vcxprojin and .vcxproj.filtersin files here into corresponding actual
.vcxproj and vcxproj.filters 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/vs10/README.txt file in glib for details where to unpack them.

It is recommended that one builds the dependencies with VS10 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 VS10
using VS project files and/or makefiles at this time of writing, For the
GTK+ stack, VS10 project files are either available under
$(srcroot)/build/vs10 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 VS10 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>\vs10\<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>\vs10\<PlatformName>\bin
 .lib files: <root>\vs10\<PlatformName>\lib
 .h files: <root>\vs10\<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/vs10 folder)
-zlib
-libpng
-(for GDK-Pixbuf, if not using GDI+) IJG JPEG
-(for GDK-Pixbuf, if not using GDI+) libtiff
 [libtiff requires zlib and IJG JPEG]
-(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/vs10/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>\vs10\<PlatformName>. For instance,
built DLLs go into <root>\vs10\<PlatformName>\bin, built LIBs into
<root>\vs10\<PlatformName>\lib and GTK+ headers into
<root>\vs10\<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.

*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 VS10 from there.

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