gtk/build/win32/vs10
Chun-wei Fan d836a52b68 build: Clean Up Visual Studio Project Generation
Use the common automake module from the previous commit in the
Makefile.am's, which means that the Makefile.am's in gdk/ and gtk/ can be
cleaned up as a result.  As a side effect, the property sheet that is used
to "install" the build results and headers can now be generated in terms of
the listing of headers to copy during 'make dist', where we can acquire
most of the list of headers to "install", so that we can largely avoid the
situation where the property sheet files are not updated in time for this,
causing missing headers when this build of GTK+ is being used.

Also use the Visual Studio Project file generation for the following
projects:
gtk3-demo
gtk3-demo-application
gtk3-icon-browser
gdk-win32
gdk-broadway
gail-util

So that the maintenace of these project files can be simplified as well.

https://bugzilla.gnome.org/show_bug.cgi?id=681965
2015-09-15 18:37:37 +08:00
..
broadwayd.vcxproj Visual Studio Builds: Fix broadwayd Build 2014-10-22 19:40:48 +08:00
broadwayd.vcxproj.filters Visual Studio Builds: Fix broadwayd Build 2014-10-22 19:40:48 +08:00
broadwayd.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
broadwayd.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gailutil.vcxproj MSVC 2010+ Builds: Fix .pdb Generation 2015-03-06 10:25:18 +08:00
gailutil.vcxproj.filters MSVC Projects: Use UNIX Line endings 2013-12-04 08:51:39 +08:00
gailutil.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gailutil.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gdk-broadway.vcxproj Rework the Visual Studio 2010 Projects a bit 2013-12-30 13:17:43 +08:00
gdk-broadway.vcxproj.filters MSVC Projects: Use UNIX Line endings 2013-12-04 08:51:39 +08:00
gdk-broadway.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gdk-broadway.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gdk-win32.vcxproj MSVC Builds: Build and "Install" GDK-Win32 GL Items 2014-12-17 16:24:54 +08:00
gdk-win32.vcxproj.filters MSVC Builds: Build and "Install" GDK-Win32 GL Items 2014-12-17 16:24:54 +08:00
gdk-win32.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gdk-win32.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gdk.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gdk.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk3-demo-application.vcxproj MSVC Projects: Use UNIX Line endings 2013-12-04 08:51:39 +08:00
gtk3-demo-application.vcxproj.filters MSVC Projects: Use UNIX Line endings 2013-12-04 08:51:39 +08:00
gtk3-demo-application.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk3-demo-application.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk3-demo.vcxproj gtk3-demo: Fix Visual Studio Builds 2015-05-20 17:36:44 +08:00
gtk3-demo.vcxproj.filters gtk3-demo: Fix Visual Studio Builds 2015-05-20 17:36:44 +08:00
gtk3-demo.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk3-demo.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk3-icon-browser.vcxproj MSVC Builds: Update icon-browser Projects 2015-03-03 14:08:51 +08:00
gtk3-icon-browser.vcxproj.filters MSVC Builds: Update icon-browser Projects 2015-03-03 14:08:51 +08:00
gtk3-icon-browser.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk3-icon-browser.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk-build-defines.props MSVC Builds: Improve Build Speed and Debugging 2015-03-03 14:07:26 +08:00
gtk-copy-gdk-broadway.props Fix Up Visual Studio Property Sheets 2014-10-24 12:53:51 +08:00
gtk-encode-symbolic-svg.vcxproj MSVC Builds: Build gtk-encode-symbolic-svg 2014-08-04 15:07:39 +08:00
gtk-encode-symbolic-svg.vcxproj.filters MSVC Builds: Build gtk-encode-symbolic-svg 2014-08-04 15:07:39 +08:00
gtk-gen-srcs.props gtk-demo: Don't Distribute demos.h 2015-06-19 23:46:05 +08:00
gtk-ignore-broadway.props Visual C++ Builds: Build Introspection for GdkWin32 2014-04-03 15:49:05 +08:00
gtk-install.props Visual Studio Builds: Fix Header "Installation" 2015-04-10 16:21:11 +08:00
gtk-install.propsin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk-install.vcxproj MSVC Builds: Rename "install" Projects 2015-02-04 13:06:16 +08:00
gtk-prebuild.vcxproj gtk-demo: Don't Distribute demos.h 2015-06-19 23:46:05 +08:00
gtk-version-paths.props.in MSVC Build Files: Use Real GTK+ Version 2014-08-07 23:11:34 +08:00
gtk.vcxproj.filtersin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk.vcxprojin build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
gtk+.sln MSVC Builds: Rename "install" Projects 2015-02-04 13:06:16 +08:00
Makefile.am build: Clean Up Visual Studio Project Generation 2015-09-15 18:37:37 +08:00
README.txt docs: Fix some old live.gnome.org URLs 2015-01-09 14:08:20 +00: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 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.

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 PythonPath in gtk-version-paths.props.
If you happen to change the PythonPath setting in gtk-version-paths.props after
opening gtk+.sln with Visual Studio, you will need to close the gtk+.sln solution,
delete all the *.sdf, *.suo and *.user files before re-attempting the build.

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 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/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.

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

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