annotate nt/README @ 318:afd57c14dfc8 r21-0b57

Import from CVS: tag r21-0b57
author cvs
date Mon, 13 Aug 2007 10:45:36 +0200
parents 341dac730539
children 03446687b7cc
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
1 Building and Installing XEmacs on Windows NT
155
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
2
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
3 David Hobley
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
4 Marc Paquette
215
1f0dabaa0855 Import from CVS: tag r20-4b6
cvs
parents: 213
diff changeset
5 Jonathan Harris
155
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
6
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
7 The port was made much easier by the groundbreaking work of Geoff Voelker
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
8 and others who worked on the GNU Emacs port to NT. Their version is available
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
9 from http://www.cs.washington.edu/homes/voelker/ntemacs.html
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
10
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
11 To get it working you will need:
155
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
12
308
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
13 1. You will need Visual C++ V4.0 or later to compile everything. Personally we
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
14 have tested V4.0, V4.2 and V5.0.
213
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
15 Note that Visual C++ assumes a couple of environment variables INCLUDE and
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
16 LIB to be set which specify the location of the includes and libraries.
308
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
17 Your PATH environment variable also needs to include the DevStudio vc\bin
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
18 and sharedide\bin directories.
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
19 Visual C++ V5.0 installs a batch file called vcvars32.bat in
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
20 c:\Program Files\DevStudio\VC\bin\ (or wherever you installed it) that you
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
21 can run before building to set up all of these environment variables.
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
22
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
23 2. Grab the latest XEmacs source from ftp.xemacs.org if necessary. All Win32
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
24 support is in the nt\ subdirectory. You'll also need the xemacs-base
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
25 package from the binary-packages subdirectory and you'll probably also
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
26 want at least the edit-utils, text-utils, cc-mode and prog-utils packages.
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
27 Unpack the packages into, say, "c:\Program Files\XEmacs\packages".
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
28
308
33bdb3d4b97f Import from CVS: tag r21-0b52
cvs
parents: 298
diff changeset
29 3. At this point you can select X or Win32 native GUI support.
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
30
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
31 If you want to build for native GUI:
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
32
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
33 1. If you want XPM image and toolbar support grab the latest version of the
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
34 xpm sources (xpm-3.4k.tar.gz at time of writing) and unpack them somewhere.
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
35 Copy nt\xpm.mak from the xemacs sources to the lib subdirectory of the
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
36 xpm sources, cd to that directory and build xpm with 'nmake -f xpm.mak'.
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
37
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
38 2. You probably also want PNG image support. Grab the latest versions of zlib
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
39 and libpng (zlib-1.1.3 and libpng-1.0.2 at time of writing), unpack them
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
40 somewhere and read the respective READMEs for details on how to build them.
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
41 The following build procedure works for zlib-1.1.3 and libpng-1.0.2:
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
42
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
43 cd to the zlib directory, type 'copy msdos\makefile.w32 Makefile' and
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
44 then type 'nmake'.
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
45
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
46 cd to the libpng directory, rename or move the zlib directory to ..\zlib
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
47 and type 'nmake -f scripts\makefile.w32'.
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
48
318
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
49 3. If you want TIFF support, grap the latest version of libtiff (tiff-v3.4
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
50 at time of writing) and unpack it somewhere. Copy nt\tiff.mak from the
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
51 xemacs sources to the contrib\winnt subdirectory of the tiff sources,
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
52 cd to that directory and build libtiff with 'nmake -f tiff.mak'. Note:
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
53 tiff.mak has only been verified to work under WinNT, not Win95 or 98.
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
54 However, the lastest distribution of libtiff includes a
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
55 contrib\win95\makefile.w95; that might work.
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
56
318
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
57 4. If you want JPEG support grab the latest version of jpegsrc (jpeg-6b at
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
58 time of writing) and read the README for details on how to build it.
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
59
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
60 5. cd to the nt subdirectory of the xemacs distribution and build xemacs:
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
61 `nmake install -f xemacs.mak`, but read on before hitting Enter.
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
62
318
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
63 6. If you're building with XPM support, add this to the nmake command line:
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
64 HAVE_XPM=1 XPM_DIR="x:\location\of\your\xpm\sources"
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
65 and similarly for JPEG and TIFF support.
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
66
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
67 If you're building with PNG support, add this to the nmake command line:
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
68 HAVE_PNG=1 PNG_DIR="x:\location\of\your\png\sources"
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
69 ZLIB_DIR="x:\location\of\your\zlib\sources"
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
70
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
71 If you want to build with GIF support, add this to the nmake command line:
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
72 HAVE_GIF=1
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
73
318
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
74 7. By default, XEmacs will look for packages in
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
75 "c:\Program Files\XEmacs\packages". If you want it to look elsewhere,
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
76 add this to the nmake command line:
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
77 PACKAGEPATH="x:\\location\\of\\your\\packages"
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
78 Note the doubled-up backslashes in that path. If you want to change the
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
79 package path after you've already built XEmacs, delete the file
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
80 .\obj\emacs.obj before rebuilding with the new value of PACKAGEPATH.
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
81
318
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
82 8. By default, XEmacs will be installed in directories under the directory
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
83 "c:\Program Files\XEmacs\XEmacs-21.0". If you want to install it
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
84 elsewhere, add this to the nmake command line:
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
85 INSTALL_DIR="x:\your\installation\directory"
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
86
318
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
87 9. Now you can press Enter. nmake will build temacs, the DOC file, update the
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
88 elc's, dump xemacs and install the relevant files in the directories under
314
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
89 the installation directory. Unless you set INSTALL_DIR above, the file that
341dac730539 Import from CVS: tag r21-0b55
cvs
parents: 308
diff changeset
90 you should run to start XEmacs will be installed as
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
91 "c:\Program Files\XEmacs\XEmacs-21.0\i386-pc-win32\runemacs.exe". You may
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
92 want to create a shortcut to that file from your Desktop or Start Menu.
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
93
318
afd57c14dfc8 Import from CVS: tag r21-0b57
cvs
parents: 314
diff changeset
94 10. The build process always creates debugging and "Source Browser" information
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
95 in the source tree for use with MS DevStudio. If you actually want to debug
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
96 XEmacs you should run XEmacs from the source directory instead of from the
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
97 installation directory. You should probably also build a debug version of
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
98 XEmacs; to do this start with a clean source tree and add DEBUG_XEMACS=1 to
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
99 the nmake command line. You probably don't want to install your debug build
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
100 so you should tell nmake to build the 'all' target instead of the 'install'
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
101 target.
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
102
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
103 To make use of the debugging and "Source Browser" information, create a new
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
104 "console" project in MS DevStudio and, under Project/Settings, set:
276
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
105 Debug: executable name = full path of src\xemacs.exe
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
106 Link: output file name = full path of src\temacs.exe
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
107 Browse Info: browse info file name = full path of src\temacs.bsc
6330739388db Import from CVS: tag r21-0b36
cvs
parents: 215
diff changeset
108 Remember to close the Source Browser file in DevStudio before rebuilding.
213
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
109
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
110
213
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
111 If you want support for X you will need:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
112
195
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
113 1. An X server. MI/X is available on the Internet for free; It is
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
114 available from: http://www.microimages.com/www/html/freestuf/mixdlfrm.htm
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
115
195
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
116 2. The MIT X11R6.3 libraries available from: ftp.x.org
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
117
195
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
118 3. You'll need to compile the MIT libraries without multi-thread support.
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
119 To do this, there is an example Win32.cf and site.def provided which
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
120 set the relevant flags. You will also need to apply the patch in
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
121 nt/X11.patch in the xc/lib/X11 directory which will fix the DLL definition
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
122 file. Once compiled and installed, you will need to apply the following
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
123 patch to Xmd.h. This is messy and better solutions would be appreciated.
298
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
124
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
125 4. Goto 2 under 'native GUI' above and add this to the nmake command line:
70ad99077275 Import from CVS: tag r21-0b47
cvs
parents: 276
diff changeset
126 HAVE_X=1 X11_DIR=x:\root\directory\of\your\X11\installation
155
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
127
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
128 --- Xmd.h~ Thu Jun 08 23:20:40 1995
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
129 +++ Xmd.h Sun Mar 16 13:09:10 1997
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
130 @@ -150,8 +150,9 @@
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
131 typedef CARD16 BITS16;
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
132 typedef CARD8 BYTE;
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
133
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
134 +#ifndef WIN32
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
135 typedef CARD8 BOOL;
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
136 -
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
137 +#endif
195
a2f645c6b9f8 Import from CVS: tag r20-3b24
cvs
parents: 169
diff changeset
138
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
139 Known Problems:
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
140 Please look at the TODO list for the current list of problems and people
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
141 working on them.
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
142
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
143 Any other problems you need clarified, please email us and we will endeavour
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 155
diff changeset
144 to provide any assistance we can:
155
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
145
213
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
146 The XEmacs NT Mailing List: xemacs-nt@xemacs.org
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
147 Subscribe address: xemacs-nt-request@xemacs.org
155
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
148
213
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
149 David Hobley
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
150 Marc Paquette
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
151 August Hill
215
1f0dabaa0855 Import from CVS: tag r20-4b6
cvs
parents: 213
diff changeset
152 Jonathan Harris
155
43dd3413c7c7 Import from CVS: tag r20-3b4
cvs
parents: 100
diff changeset
153
213
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents: 195
diff changeset
154 and others.