source: trunk/third/gtk2/README.win32 @ 18785

Revision 18785, 3.8 KB checked in by ghudson, 21 years ago (diff)
This commit was generated by cvs2svn to compensate for changes in r18784, which included commits to RCS files with non-trunk default branches.
Line 
1The Win32 port of GTK+ is a work in progress, and not as stable or
2correct as the Unix/X11 version. For more information about the Win32
3port, and prebuilt runtime and developer packages see
4http://www.gimp.org/win32/ .
5
6There is a gtk-1-3-win32-production branch of GTK+ that was branched
7off from before the addition of the no-flicker and other recent
8functionality. That is what should be used by "production" code until
9this CVS HEAD (2.0) version is useable. (But note, the Win32 backend
10has never been claimed to be "production quality", although it works
11surprisingly well for the GIMP.)
12
13Building GTK+ on Win32
14======================
15
16There are two ways to build GTK+ for win32:
17
181) Use the autoconf-generated configure script, and the resulting
19Makefiles (which use libtool and gcc to do the compilation). I use
20this myself, but it might be hell to setup correctly.
21
22Personally I run configure with:
23CC='gcc -mpentium -fnative-struct' CPPFLAGS='-I/target/include' CFLAGS=-O2 LDFLAGS='-L/target/lib' ./configure --disable-static --prefix=/target --with-gdktarget=win32 --with-wintab=/src/wtkit126 --with-ie55=/src/workshop/ie55_lib --host=i386-pc-mingw32 --enable-maintainer-mode
24
25It might well be that in order for this to work, you will have to get
26a bleeding-edge version of libtool for Win32, run libtoolize yourself,
27and then run autoconf to generate the configure script.
28
292) Use the Microsoft compiler, cl and Make, nmake. Say nmake -f
30makefile.msc in gdk and gtk.
31
32Alternative 1 also generates Microsoft import libraries (.lib), if you
33have lib.exe available. It might also work for cross-compilation from
34Unix.
35
36Note that I use method 1 myself. Hans Breuer has been taking care of
37the MSVC makefiles. At times, we disagree a bit about various issues,
38and for instance the makefile.msc files will not produce identically
39named DLLs and import libraries as the "autoconfiscated" makefiles and
40libtool do. If this bothers you, you will have to fix the makefiles.
41
42Using GTK+ on Win32
43===================
44
45To use GTK+ on Win32, you also need either one of the above mentioned
46compilers. Other compilers might work, but don't count on it. Look for
47prebuilt developer packages (DLLs, import libraries, headers) on the
48above website.
49
50Multi-threaded use of GTK+ on Win32
51===================================
52
53Multi-threaded GTK+ programs might work in special simple cases, but
54not in general. Sorry. If you have all GTK+ and GDK calls in the same
55thread, it might work. Otherwise, probably not at all. Possible ways
56to fix this are being investigated.
57
58Wintab
59======
60
61The tablet support uses the Wintab API. The Wintab development kit can
62be downloaded from http://www.pointing.com. Pass the --with-wintab
63flag to configure if you use that. If you use nmake and you don't care
64for Wintab, undefine HAVE_WINTAB in config.h.win32 and remove
65references to the wntab32x library from the makefile before building.
66
67Libintl
68=======
69
70GTK wants to be built with the GNU "intl" library for
71internationalisation (i18n). Get the version ported to Win32 (not a
72very big deal) from the web site mentioned above. The "intl" library
73as gets built as a DLL called libintl-1.dll. If you don't want any
74i18n stuff, undefine ENABLE_NLS, HAVE_GETTEXT and HAVE_LIBINTL in the
75config.h.win32 file, and remove references to the intl library from
76the makefiles.
77
78ActiveIMM
79=========
80
81If you want to build a GTK+ that supports ActiveIMM (the Input Method
82Manager for non-EastAsia locales that can be used on Win9x/NT4), you
83need the dimm.h header file. That is somewhat difficult to find, but
84http://msdn.microsoft.com/downloads/samples/internet/wizard/ seems to
85be a good place to look nowadays. If you use "autoconfiscated" build,
86pass the --with-ie55 flag to configure specifyin the location of the
87ie55_lib directory created by downloading the IE5.5 headers and libs
88from the above URL.
89
90--Tor Lillqvist <tml@iki.fi>
Note: See TracBrowser for help on using the repository browser.