Mercurial > emacs
comparison nt/INSTALL @ 62675:114ecd5ee47b
Add more pointers to ports of Unix tools to Windows, and to the Emacs Wiki
(which contains building instructions for Windows). Reword image library
instructions and remove obsolete incompatibility information.
author | Juanma Barranquero <lekktu@gmail.com> |
---|---|
date | Tue, 24 May 2005 10:40:51 +0000 |
parents | 64443697a546 |
children | 850c9d934e12 |
comparison
equal
deleted
inserted
replaced
62674:100b8f001349 | 62675:114ecd5ee47b |
---|---|
1 Building and Installing Emacs | 1 Building and Installing Emacs |
2 on Windows NT/2K/XP and Windows 95/98/ME | 2 on Windows NT/2K/XP and Windows 95/98/ME |
3 | 3 |
4 Copyright (c) 2001,2004 Free Software Foundation, Inc. | 4 Copyright (c) 2001,2004,2005 Free Software Foundation, Inc. |
5 See the end of the file for copying permissions. | 5 See the end of the file for copying permissions. |
6 | 6 |
7 If you used WinZip to unpack the distribution, we suggest to | 7 If you used WinZip to unpack the distribution, we suggest to |
8 remove the files and unpack again with a different program! | 8 remove the files and unpack again with a different program! |
9 WinZip is known to create some subtle and hard to debug problems, | 9 WinZip is known to create some subtle and hard to debug problems, |
19 In addition to this file, you should also read INSTALL.CVS in the | 19 In addition to this file, you should also read INSTALL.CVS in the |
20 parent directory, and make sure that you have a version of "touch.exe" | 20 parent directory, and make sure that you have a version of "touch.exe" |
21 in your path, and that it will create files that do not yet exist. | 21 in your path, and that it will create files that do not yet exist. |
22 | 22 |
23 To compile Emacs, you will need either Microsoft Visual C++ 2.0 or | 23 To compile Emacs, you will need either Microsoft Visual C++ 2.0 or |
24 later and nmake, or a Windows port of GCC 2.95 or later with Mingw | 24 later and nmake, or a Windows port of GCC 2.95 or later with MinGW |
25 and W32 API support and a port of GNU make. You can use the Cygwin | 25 and W32 API support and a port of GNU make. You can use the Cygwin |
26 ports of GCC, but Emacs requires the Mingw headers and libraries to | 26 ports of GCC, but Emacs requires the MinGW headers and libraries to |
27 build (latest versions of the Cygwin toolkit, at least since v1.3.3, | 27 build (latest versions of the Cygwin toolkit, at least since v1.3.3, |
28 include the MinGW headers and libraries as an integral part). | 28 include the MinGW headers and libraries as an integral part). |
29 | 29 |
30 Other compilers may work, but specific reports from people that have | 30 Other compilers may work, but specific reports from people that have |
31 tried suggest that the Intel C compiler (for example) may produce an | 31 tried suggest that the Intel C compiler (for example) may produce an |
32 Emacs executable with strange filename completion behaviour. Unless | 32 Emacs executable with strange filename completion behaviour. Unless |
33 you would like to assist by finding and fixing the cause of any bugs | 33 you would like to assist by finding and fixing the cause of any bugs |
34 like this, we recommend the use of the supported compilers mentioned | 34 like this, we recommend the use of the supported compilers mentioned |
35 in the previous paragraph. | 35 in the previous paragraph. |
36 | 36 |
37 You will also need a copy of the Posix cp, rm and mv programs. These | 37 You will also need a copy of the Posix cp, rm and mv programs. These |
38 and other useful Posix utilities can be obtained from the Mingw or | 38 and other useful Posix utilities can be obtained from one of several |
39 Cygwin projects. | 39 projects: |
40 | |
41 * http://www.mingw.org/ ( MinGW ) | |
42 * http://www.cygwin.org/ ( Cygwin ) | |
43 * http://unxutils.sourceforge.net/ ( UnxUtils ) | |
44 * http://gnuwin32.sourceforge.net/ ( GnuWin32 ) | |
40 | 45 |
41 If you build Emacs on Windows 9X or ME, not on Windows 2K/XP or | 46 If you build Emacs on Windows 9X or ME, not on Windows 2K/XP or |
42 Windows NT, we suggest to install the Cygwin port of Bash. | 47 Windows NT, we suggest to install the Cygwin port of Bash. |
43 | 48 |
44 Please see http://www.mingw.org for pointers to GCC/Mingw and binaries. | 49 Additional instructions and help for building Emacs on Windows can be |
50 found at the Emacs Wiki: | |
51 | |
52 http://www.emacswiki.org/cgi-bin/wiki/WThirtyTwoInstallationKit | |
45 | 53 |
46 For reference, here is a list of which builds of GNU make are known | 54 For reference, here is a list of which builds of GNU make are known |
47 to work or not, and whether they work in the presence and/or absence | 55 to work or not, and whether they work in the presence and/or absence |
48 of sh.exe, the Cygwin port of Bash. Note that any version of make | 56 of sh.exe, the Cygwin port of Bash. Note that any version of make |
49 that is compiled with Cygwin will only work with Cygwin tools, due to | 57 that is compiled with Cygwin will only work with Cygwin tools, due to |
107 variables, or by specifying --cflags -I... options on the command-line | 115 variables, or by specifying --cflags -I... options on the command-line |
108 to configure.bat. The configure script will report whether it was | 116 to configure.bat. The configure script will report whether it was |
109 able to detect the headers. | 117 able to detect the headers. |
110 | 118 |
111 To use the external image support, the DLLs implementing the | 119 To use the external image support, the DLLs implementing the |
112 functionality must be found when Emacs is started, either on the PATH, | 120 functionality must be found when Emacs first needs them, either on the |
113 or in the same directory as emacs.exe. Failure to find a library is | 121 PATH, or in the same directory as emacs.exe. Failure to find a |
114 not an error; the associated image format will simply be unavailable. | 122 library is not an error; the associated image format will simply be |
123 unavailable. Note that once Emacs has determined that a library can | |
124 not be found, there's no way to force it to try again, other than | |
125 restarting. See the variable `image-library-alist' to configure the | |
126 expected names of the libraries. | |
115 | 127 |
116 Some image libraries have dependencies on one another, or on zlib. | 128 Some image libraries have dependencies on one another, or on zlib. |
117 For example, tiff support depends on the jpeg library. If you did not | 129 For example, tiff support depends on the jpeg library. If you did not |
118 compile the libraries yourself, you must make sure that any dependency | 130 compile the libraries yourself, you must make sure that any dependency |
119 is in the PATH or otherwise accesible and that the binaries are | 131 is in the PATH or otherwise accesible and that the binaries are |
120 compatible (for example, that they were built with the same compiler). | 132 compatible (for example, that they were built with the same compiler). |
121 | 133 |
122 Binaries for the image libraries (among many others) can be found at | 134 Binaries for the image libraries (among many others) can be found at |
123 GnuWin32 (http://gnuwin32.sourceforge.net). These are built with | 135 the GnuWin32 project. These are built with MinGW, but they can be |
124 MinGW, and so are very compatible with GCC/MinGW builds of Emacs (like | 136 used with both GCC/MinGW and MSVC builds of Emacs. |
125 the official binary tarballs for Windows). Compatibility with MSVC, | |
126 on the other hand, is still weak and should not be trusted in | |
127 production environments; if you really need an MSVC-compiled Emacs | |
128 with image support, you should try to build the required libraries | |
129 with the same compiler (though it can be extremely non-trivial, and | |
130 we'll be interested on hearing of any such effort). | |
131 | 137 |
132 * Building | 138 * Building |
133 | 139 |
134 After running configure, simply run the appropriate `make' program for | 140 After running configure, simply run the appropriate `make' program for |
135 your compiler to build Emacs. For MSVC, this is nmake; for GCC, it is | 141 your compiler to build Emacs. For MSVC, this is nmake; for GCC, it is |
160 to create a Start menu icon for Emacs. | 166 to create a Start menu icon for Emacs. |
161 | 167 |
162 * Trouble-shooting | 168 * Trouble-shooting |
163 | 169 |
164 The main problems that are likely to be encountered when building | 170 The main problems that are likely to be encountered when building |
165 Emacs stem from using an old version of GCC, or old Mingw or W32 API | 171 Emacs stem from using an old version of GCC, or old MinGW or W32 API |
166 headers. Additionally, cygwin ports of GNU make may require the Emacs | 172 headers. Additionally, cygwin ports of GNU make may require the Emacs |
167 source tree to be mounted with text!=binary, because the makefiles | 173 source tree to be mounted with text!=binary, because the makefiles |
168 generated by configure.bat necessarily use DOS line endings. Also, | 174 generated by configure.bat necessarily use DOS line endings. Also, |
169 cygwin ports of make must run in UNIX mode, either by specifying | 175 cygwin ports of make must run in UNIX mode, either by specifying |
170 --unix on the command line, or MAKE_MODE=UNIX in the environment. | 176 --unix on the command line, or MAKE_MODE=UNIX in the environment. |