2011-08-31 06:28:47 +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:
|
|
|
|
|
2014-04-08 15:42:36 +00:00
|
|
|
https://wiki.gnome.org/Projects/GTK+/Win32/MSVCCompilationOfGTKStack
|
2010-03-21 16:24:24 +00:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2011-04-17 16:17:51 +00:00
|
|
|
You will need the parts from below in the GTK+ stack: GDK-Pixbuf, Pango,
|
2011-07-20 02:40:54 +00:00
|
|
|
ATK and GLib. External dependencies are at least Cairo
|
2011-04-17 16:17:51 +00:00
|
|
|
(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.
|
|
|
|
|
2014-02-21 10:00:29 +00:00
|
|
|
You will also need a Python 2.6+/3.x interpretor installed on your system,
|
2013-11-27 10:05:32 +00:00
|
|
|
which can be obtained from the official installers available from
|
|
|
|
http://www.python.org. Please note that the Python interpretor (python.exe)
|
2014-02-21 10:00:29 +00:00
|
|
|
either needs to be in your PATH before attempting the build of GTK+, or it
|
2017-08-28 06:58:42 +00:00
|
|
|
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
|
2014-02-21 10:00:29 +00:00
|
|
|
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.
|
2013-11-27 10:05:32 +00:00
|
|
|
|
2011-04-17 16:17:51 +00:00
|
|
|
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
|
2011-05-18 04:02:10 +00:00
|
|
|
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
|
2011-04-17 16:17:51 +00:00
|
|
|
GTK+ stack, VS9 project files are either available under
|
2011-07-20 02:40:54 +00:00
|
|
|
$(srcroot)/build/vs9 in the case of GLib (stable/unstable), ATK
|
|
|
|
(stable/unstable) and GDK-Pixbuf (unstable), and should be in the next
|
2011-04-17 16:17:51 +00:00
|
|
|
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)
|
|
|
|
|
2011-05-18 04:02:10 +00:00
|
|
|
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
|
|
|
|
|
2011-04-17 16:17:51 +00:00
|
|
|
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
|
2014-09-30 05:00:32 +00:00
|
|
|
-(for GDK-Pixbuf, if not using GDI+) IJG JPEG or libjpeg-turbo
|
2011-04-26 16:53:16 +00:00
|
|
|
-(for GDK-Pixbuf, if not using GDI+) libtiff
|
2014-09-30 05:00:32 +00:00
|
|
|
[libtiff requires zlib and IJG JPEG or libjpeg-turbo]
|
2011-04-26 16:53:16 +00:00
|
|
|
-(for GDK-Pixbuf, if not using GDI+) jasper [jpeg-2000 library])
|
2011-04-17 16:17:51 +00:00
|
|
|
-(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)
|
2011-07-20 02:40:54 +00:00
|
|
|
-GLib **
|
2011-04-17 16:17:51 +00:00
|
|
|
-Cairo (inclusive of Cairo-GObject)
|
2011-07-20 02:40:54 +00:00
|
|
|
-ATK**
|
|
|
|
-Pango**
|
|
|
|
-GDK-Pixbuf**
|
2011-04-17 16:17:51 +00:00
|
|
|
(note the last 3 dependencies are not interdependent, so the last 3
|
|
|
|
dependencies can be built in any order)
|
2010-03-21 16:24:24 +00:00
|
|
|
|
|
|
|
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
|
2011-01-23 16:10:19 +00:00
|
|
|
<root>\vs9\<PlatformName>\include\gtk-3.0. This is then from where
|
2010-03-21 16:24:24 +00:00
|
|
|
project files higher in the stack are supposed to look for them, not
|
|
|
|
from a specific GLib source tree.
|
|
|
|
|
2017-08-28 08:18:24 +00:00
|
|
|
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.
|
|
|
|
|
2014-09-30 05:00:32 +00:00
|
|
|
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+.
|
|
|
|
|
2011-05-18 04:02:10 +00:00
|
|
|
*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.
|
2011-04-17 16:17:51 +00:00
|
|
|
|
2011-07-20 02:40:54 +00:00
|
|
|
**:Put the sources of the packages marked with ** in <root>\<package-
|
2011-05-18 04:02:10 +00:00
|
|
|
source-tree>, and build with VS9 from there.
|
|
|
|
|
2010-03-21 16:24:24 +00:00
|
|
|
--Tor Lillqvist <tml@iki.fi>
|
2011-04-17 16:17:51 +00:00
|
|
|
--Updated by Chun-wei Fan <fanc999@yahoo.com.tw>
|