Mercurial > vim
annotate src/Make_cyg.mak @ 6247:fe1827921d50 v7.4.458
updated for version 7.4.458
Problem: Issue 252: Cursor moves in a zero-height window.
Solution: Check for zero height. (idea by Christian Brabandt)
author | Bram Moolenaar <bram@vim.org> |
---|---|
date | Tue, 23 Sep 2014 18:37:56 +0200 |
parents | ab71bb81b84e |
children | 4c29b75cae19 |
rev | line source |
---|---|
7 | 1 # |
2 # Makefile for VIM on Win32, using Cygnus gcc | |
6126 | 3 # Updated by Dan Sharp. |
4 # Last Change: 2014 Aug 10 | |
146 | 5 # |
6 # Also read INSTALLpc.txt! | |
7 | 7 # |
8 # This compiles Vim as a Windows application. If you want Vim to run as a | |
9 # Cygwin application use the Makefile (just like on Unix). | |
10 # | |
11 # GUI no or yes: set to yes if you want the GUI version (yes) | |
6110 | 12 # DIRECTX no or yes: set to yes if you want use DirectWrite (no) |
7 | 13 # PERL define to path to Perl dir to get Perl support (not defined) |
14 # PERL_VER define to version of Perl being used (56) | |
15 # DYNAMIC_PERL no or yes: set to yes to load the Perl DLL dynamically (yes) | |
16 # PYTHON define to path to Python dir to get PYTHON support (not defined) | |
17 # PYTHON_VER define to version of Python being used (22) | |
18 # DYNAMIC_PYTHON no or yes: use yes to load the Python DLL dynamically (yes) | |
2329
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
19 # PYTHON3 define to path to Python3 dir to get PYTHON3 support (not defined) |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
20 # PYTHON3_VER define to version of Python3 being used (22) |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
21 # DYNAMIC_PYTHON3 no or yes: use yes to load the Python3 DLL dynamically (yes) |
7 | 22 # TCL define to path to TCL dir to get TCL support (not defined) |
23 # TCL_VER define to version of TCL being used (83) | |
24 # DYNAMIC_TCL no or yes: use yes to load the TCL DLL dynamically (yes) | |
25 # RUBY define to path to Ruby dir to get Ruby support (not defined) | |
3959 | 26 # RUBY_VER define to version of Ruby being used (16) |
27 # RUBY_VER_LONG same, but in format with dot. (1.6) | |
28 # You must set RUBY_VER_LONG when changing RUBY_VER. | |
29 # You must set RUBY_API_VER version to RUBY_VER_LONG. | |
30 # Don't set ruby API version to RUBY_VER like 191. | |
7 | 31 # DYNAMIC_RUBY no or yes: use yes to load the Ruby DLL dynamically (yes) |
128 | 32 # MZSCHEME define to path to MzScheme dir to get MZSCHEME support (not defined) |
33 # MZSCHEME_VER define to version of MzScheme being used (209_000) | |
34 # DYNAMIC_MZSCHEME no or yes: use yes to load the MzScheme DLLs dynamically (yes) | |
146 | 35 # MZSCHEME_DLLS path to MzScheme DLLs (libmzgc and libmzsch), for "static" build. |
2628 | 36 # MZSCHEME_USE_RACKET define to use "racket" instead of "mzsch". |
2320
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
37 # LUA define to path to Lua dir to get Lua support (not defined) |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
38 # LUA_VER define to version of Lua being used (51) |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
39 # DYNAMIC_LUA no or yes: use yes to load the Lua DLL dynamically (yes) |
7 | 40 # GETTEXT no or yes: set to yes for dynamic gettext support (yes) |
41 # ICONV no or yes: set to yes for dynamic iconv support (yes) | |
42 # MBYTE no or yes: set to yes to include multibyte support (yes) | |
43 # IME no or yes: set to yes to include IME support (yes) | |
44 # DYNAMIC_IME no or yes: set to yes to load imm32.dll dynamically (yes) | |
45 # OLE no or yes: set to yes to make OLE gvim (no) | |
46 # DEBUG no or yes: set to yes if you wish a DEBUGging build (no) | |
39 | 47 # CPUNR No longer supported, use ARCH. |
2088
4ec11bb387a5
updated for version 7.2.372
Bram Moolenaar <bram@zimbu.org>
parents:
1951
diff
changeset
|
48 # ARCH i386 through pentium4: select -march argument to compile with |
4ec11bb387a5
updated for version 7.2.372
Bram Moolenaar <bram@zimbu.org>
parents:
1951
diff
changeset
|
49 # (i386) |
7 | 50 # USEDLL no or yes: set to yes to use the Runtime library DLL (no) |
51 # For USEDLL=yes the cygwin1.dll is required to run Vim. | |
4124 | 52 # For "no" the mingw-gcc-g++ package or the mingw64-i686-gcc-g++ |
4352 | 53 # package is required to compile Vim. Or set CC to gcc-3 and add |
2309
543ea69d037f
Add clipboard support in Mac console. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2192
diff
changeset
|
54 # -L/lib/w32api to EXTRA_LIBS. |
7 | 55 # POSTSCRIPT no or yes: set to yes for PostScript printing (no) |
56 # FEATURES TINY, SMALL, NORMAL, BIG or HUGE (BIG) | |
3652 | 57 # WINVER Lowest Win32 version to support. (0x0500) |
7 | 58 # CSCOPE no or yes: to include cscope interface support (yes) |
59 # OPTIMIZE SPACE, SPEED, or MAXSPEED: set optimization level (MAXSPEED) | |
60 # NETBEANS no or yes: to include netbeans interface support (yes when GUI | |
61 # is yes) | |
856 | 62 # NBDEBUG no or yes: to include netbeans interface debugging support (no) |
7 | 63 # XPM define to path to XPM dir to get XPM image support (not defined) |
64 #>>>>> choose options: | |
65 ifndef GUI | |
66 GUI=yes | |
67 endif | |
68 | |
69 ifndef FEATURES | |
70 FEATURES = BIG | |
71 endif | |
72 | |
73 ifndef GETTEXT | |
74 GETTEXT = yes | |
75 endif | |
76 | |
77 ifndef ICONV | |
78 ICONV = yes | |
79 endif | |
80 | |
81 ifndef MBYTE | |
82 MBYTE = yes | |
83 endif | |
84 | |
85 ifndef IME | |
86 IME = yes | |
87 endif | |
88 | |
12 | 89 ifndef ARCH |
90 ARCH = i386 | |
7 | 91 endif |
92 | |
6110 | 93 ifndef DIRECTX |
94 DIRECTX = no | |
95 endif | |
96 | |
7 | 97 ifndef WINVER |
3652 | 98 WINVER = 0x0500 |
7 | 99 endif |
100 | |
101 ifndef CSCOPE | |
102 CSCOPE = yes | |
103 endif | |
104 | |
105 ifndef NETBEANS | |
106 ifeq ($(GUI),yes) | |
107 NETBEANS = yes | |
108 endif | |
109 endif | |
110 | |
111 ifndef OPTIMIZE | |
112 OPTIMIZE = MAXSPEED | |
113 endif | |
114 | |
4137 | 115 |
116 # Link against the shared version of libstdc++ by default. Set | |
117 # STATIC_STDCPLUS to "yes" to link against static version instead. | |
118 ifndef STATIC_STDCPLUS | |
119 STATIC_STDCPLUS=no | |
120 endif | |
121 | |
7 | 122 ### See feature.h for a list of optionals. |
123 ### Any other defines can be included here. | |
124 | |
125 DEFINES = -DWIN32 -DHAVE_PATHDEF -DFEAT_$(FEATURES) \ | |
126 -DWINVER=$(WINVER) -D_WIN32_WINNT=$(WINVER) | |
5141
afbc9dd67cea
updated for version 7.3.1313
Bram Moolenaar <bram@vim.org>
parents:
4724
diff
changeset
|
127 ifeq ($(ARCH),x86-64) |
afbc9dd67cea
updated for version 7.3.1313
Bram Moolenaar <bram@vim.org>
parents:
4724
diff
changeset
|
128 DEFINES+=-DMS_WIN64 |
afbc9dd67cea
updated for version 7.3.1313
Bram Moolenaar <bram@vim.org>
parents:
4724
diff
changeset
|
129 endif |
39 | 130 INCLUDES = -march=$(ARCH) -Iproto |
7 | 131 |
132 #>>>>> name of the compiler and linker, name of lib directory | |
4124 | 133 ifeq (yes, $(USEDLL)) |
134 # CROSS_COMPILE is used for the gvimext DLL. | |
135 CROSS_COMPILE = i686-pc-mingw32- | |
7 | 136 CC = gcc |
137 RC = windres | |
4124 | 138 else |
139 # i686-pc-mingw32-gcc, i686-w64-mingw32-gcc or gcc-3 can be used. | |
140 CROSS_COMPILE = i686-pc-mingw32- | |
141 CC = $(CROSS_COMPILE)gcc | |
142 RC = $(CROSS_COMPILE)windres | |
143 endif | |
7 | 144 |
145 ############################## | |
146 # DYNAMIC_PERL=yes and no both work | |
147 ############################## | |
148 ifdef PERL | |
149 DEFINES += -DFEAT_PERL | |
150 INCLUDES += -I$(PERL)/lib/CORE | |
151 EXTRA_OBJS += $(OUTDIR)/if_perl.o | |
152 | |
153 ifndef DYNAMIC_PERL | |
154 DYNAMIC_PERL = yes | |
155 endif | |
156 | |
157 ifndef PERL_VER | |
158 PERL_VER = 56 | |
159 endif | |
160 | |
161 ifeq (yes, $(DYNAMIC_PERL)) | |
162 DEFINES += -DDYNAMIC_PERL -DDYNAMIC_PERL_DLL=\"perl$(PERL_VER).dll\" | |
163 else | |
5537 | 164 EXTRA_LIBS += -L$(PERL)/lib/CORE -lperl$(PERL_VER) |
7 | 165 endif |
166 endif | |
167 | |
168 ############################## | |
169 # DYNAMIC_PYTHON=yes works. | |
170 # DYNAMIC_PYTHON=no does not (unresolved externals on link). | |
171 ############################## | |
172 ifdef PYTHON | |
173 DEFINES += -DFEAT_PYTHON | |
174 EXTRA_OBJS += $(OUTDIR)/if_python.o | |
175 | |
176 ifndef DYNAMIC_PYTHON | |
177 DYNAMIC_PYTHON = yes | |
178 endif | |
179 | |
180 ifndef PYTHON_VER | |
181 PYTHON_VER = 22 | |
182 endif | |
183 | |
184 ifeq (yes, $(DYNAMIC_PYTHON)) | |
185 DEFINES += -DDYNAMIC_PYTHON -DDYNAMIC_PYTHON_DLL=\"python$(PYTHON_VER).dll\" | |
186 else | |
187 EXTRA_LIBS += $(PYTHON)/libs/python$(PYTHON_VER).lib | |
188 endif | |
189 endif | |
190 | |
191 ############################## | |
2329
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
192 # DYNAMIC_PYTHON3=yes works. |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
193 # DYNAMIC_PYTHON3=no does not (unresolved externals on link). |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
194 ############################## |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
195 ifdef PYTHON3 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
196 DEFINES += -DFEAT_PYTHON3 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
197 EXTRA_OBJS += $(OUTDIR)/if_python3.o |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
198 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
199 ifndef DYNAMIC_PYTHON3 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
200 DYNAMIC_PYTHON3 = yes |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
201 endif |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
202 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
203 ifndef PYTHON3_VER |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
204 PYTHON3_VER = 31 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
205 endif |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
206 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
207 ifeq (yes, $(DYNAMIC_PYTHON3)) |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
208 DEFINES += -DDYNAMIC_PYTHON3 -DDYNAMIC_PYTHON3_DLL=\"python$(PYTHON3_VER).dll\" |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
209 else |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
210 EXTRA_LIBS += $(PYTHON3)/libs/python$(PYTHON3_VER).lib |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
211 endif |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
212 endif |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
213 |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
214 ############################## |
7 | 215 # DYNAMIC_RUBY=yes works. |
216 # DYNAMIC_RUBY=no does not (process exits). | |
217 ############################## | |
218 ifdef RUBY | |
219 | |
4124 | 220 ifndef DYNAMIC_RUBY |
221 DYNAMIC_RUBY=yes | |
222 endif | |
223 # Set default value | |
7 | 224 ifndef RUBY_VER |
4124 | 225 RUBY_VER = 16 |
7 | 226 endif |
227 ifndef RUBY_VER_LONG | |
4124 | 228 RUBY_VER_LONG = 1.6 |
7 | 229 endif |
4124 | 230 ifndef RUBY_API_VER |
231 RUBY_API_VER = $(subst .,,$(RUBY_VER_LONG)) | |
7 | 232 endif |
233 | |
4124 | 234 ifndef RUBY_PLATFORM |
7 | 235 ifeq ($(RUBY_VER), 16) |
236 RUBY_PLATFORM = i586-mswin32 | |
237 else | |
4124 | 238 ifneq ($(wildcard $(RUBY)/lib/ruby/$(RUBY_VER_LONG)/i386-mingw32),) |
239 RUBY_PLATFORM = i386-mingw32 | |
240 else | |
4193 | 241 ifneq ($(wildcard $(RUBY)/lib/ruby/$(RUBY_VER_LONG)/x64-mingw32),) |
242 RUBY_PLATFORM = x64-mingw32 | |
243 else | |
7 | 244 RUBY_PLATFORM = i386-mswin32 |
245 endif | |
4124 | 246 endif |
247 endif | |
4193 | 248 endif |
4124 | 249 |
7 | 250 ifndef RUBY_INSTALL_NAME |
4124 | 251 ifeq ($(RUBY_VER), 16) |
252 RUBY_INSTALL_NAME = mswin32-ruby$(RUBY_API_VER) | |
253 else | |
4193 | 254 ifeq ($(ARCH),x86-64) |
255 RUBY_INSTALL_NAME = x64-msvcrt-ruby$(RUBY_API_VER) | |
256 else | |
4124 | 257 RUBY_INSTALL_NAME = msvcrt-ruby$(RUBY_API_VER) |
7 | 258 endif |
259 endif | |
4193 | 260 endif |
7 | 261 |
3959 | 262 ifeq (19, $(word 1,$(sort 19 $(RUBY_VER)))) |
263 RUBY_19_OR_LATER = 1 | |
264 endif | |
265 | |
7 | 266 DEFINES += -DFEAT_RUBY |
4124 | 267 ifneq ($(findstring w64-mingw32,$(CC)),) |
268 # A workaround for mingw-w64 | |
269 DEFINES += -DHAVE_STRUCT_TIMESPEC -DHAVE_STRUCT_TIMEZONE | |
270 endif | |
7 | 271 INCLUDES += -I$(RUBY)/lib/ruby/$(RUBY_VER_LONG)/$(RUBY_PLATFORM) |
3959 | 272 ifdef RUBY_19_OR_LATER |
273 INCLUDES += -I$(RUBY)/include/ruby-$(RUBY_VER_LONG) -I$(RUBY)/include/ruby-$(RUBY_VER_LONG)/$(RUBY_PLATFORM) | |
274 endif | |
7 | 275 EXTRA_OBJS += $(OUTDIR)/if_ruby.o |
276 | |
277 ifeq (yes, $(DYNAMIC_RUBY)) | |
278 DEFINES += -DDYNAMIC_RUBY -DDYNAMIC_RUBY_DLL=\"$(RUBY_INSTALL_NAME).dll\" | |
279 DEFINES += -DDYNAMIC_RUBY_VER=$(RUBY_VER) | |
280 else | |
5515 | 281 EXTRA_LIBS += $(RUBY)/lib/$(RUBY_INSTALL_NAME) |
7 | 282 endif |
283 endif | |
284 | |
285 ############################## | |
128 | 286 # DYNAMIC_MZSCHEME=yes works |
287 # DYNAMIC_MZSCHEME=no works too | |
288 ############################## | |
289 ifdef MZSCHEME | |
290 DEFINES += -DFEAT_MZSCHEME | |
291 INCLUDES += -I$(MZSCHEME)/include | |
292 EXTRA_OBJS += $(OUTDIR)/if_mzsch.o | |
293 | |
294 ifndef DYNAMIC_MZSCHEME | |
295 DYNAMIC_MZSCHEME = yes | |
296 endif | |
297 | |
298 ifndef MZSCHEME_VER | |
299 MZSCHEME_VER = 209_000 | |
300 endif | |
301 | |
1951 | 302 ifndef MZSCHEME_PRECISE_GC |
303 MZSCHEME_PRECISE_GC=no | |
304 endif | |
305 | |
306 # for version 4.x we need to generate byte-code for Scheme base | |
307 ifndef MZSCHEME_GENERATE_BASE | |
308 MZSCHEME_GENERATE_BASE=no | |
309 endif | |
310 | |
2628 | 311 ifndef MZSCHEME_USE_RACKET |
312 MZSCHEME_MAIN_LIB=mzsch | |
313 else | |
314 MZSCHEME_MAIN_LIB=racket | |
315 endif | |
316 | |
128 | 317 ifeq (yes, $(DYNAMIC_MZSCHEME)) |
2628 | 318 DEFINES += -DDYNAMIC_MZSCHEME -DDYNAMIC_MZSCH_DLL=\"lib$(MZSCHEME_MAIN_LIB)$(MZSCHEME_VER).dll\" -DDYNAMIC_MZGC_DLL=\"libmzgc$(MZSCHEME_VER).dll\" |
128 | 319 else |
320 ifndef MZSCHEME_DLLS | |
321 MZSCHEME_DLLS = $(MZSCHEME) | |
322 endif | |
1951 | 323 ifeq (yes,$(MZSCHEME_PRECISE_GC)) |
2628 | 324 MZSCHEME_LIB=-l$(MZSCHEME_MAIN_LIB)$(MZSCHEME_VER) |
1951 | 325 else |
2628 | 326 MZSCHEME_LIB = -l$(MZSCHEME_MAIN_LIB)$(MZSCHEME_VER) -lmzgc$(MZSCHEME_VER) |
1951 | 327 endif |
328 EXTRA_LIBS += -L$(MZSCHEME_DLLS) -L$(MZSCHEME_DLLS)/lib $(MZSCHEME_LIB) | |
329 endif | |
330 ifeq (yes,$(MZSCHEME_GENERATE_BASE)) | |
331 DEFINES += -DINCLUDE_MZSCHEME_BASE | |
332 MZ_EXTRA_DEP += mzscheme_base.c | |
333 endif | |
334 ifeq (yes,$(MZSCHEME_PRECISE_GC)) | |
335 DEFINES += -DMZ_PRECISE_GC | |
128 | 336 endif |
337 endif | |
338 | |
339 ############################## | |
7 | 340 # DYNAMIC_TCL=yes and no both work. |
341 ############################## | |
342 ifdef TCL | |
343 DEFINES += -DFEAT_TCL | |
344 INCLUDES += -I$(TCL)/include | |
345 EXTRA_OBJS += $(OUTDIR)/if_tcl.o | |
346 | |
347 ifndef DYNAMIC_TCL | |
348 DYNAMIC_TCL = yes | |
349 endif | |
350 | |
351 ifndef TCL_VER | |
352 TCL_VER = 83 | |
353 endif | |
354 | |
355 ifeq (yes, $(DYNAMIC_TCL)) | |
356 DEFINES += -DDYNAMIC_TCL -DDYNAMIC_TCL_DLL=\"tcl$(TCL_VER).dll\" | |
357 EXTRA_LIBS += $(TCL)/lib/tclstub$(TCL_VER).lib | |
358 else | |
359 EXTRA_LIBS += $(TCL)/lib/tcl$(TCL_VER).lib | |
360 endif | |
361 endif | |
362 | |
363 ############################## | |
2320
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
364 # DYNAMIC_LUA=yes works. |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
365 # DYNAMIC_LUA=no does not (unresolved externals on link). |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
366 ############################## |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
367 ifdef LUA |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
368 DEFINES += -DFEAT_LUA |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
369 INCLUDES += -I$(LUA)/include |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
370 EXTRA_OBJS += $(OUTDIR)/if_lua.o |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
371 |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
372 ifndef DYNAMIC_LUA |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
373 DYNAMIC_LUA = yes |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
374 endif |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
375 |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
376 ifndef LUA_VER |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
377 LUA_VER = 51 |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
378 endif |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
379 |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
380 ifeq (yes, $(DYNAMIC_LUA)) |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
381 DEFINES += -DDYNAMIC_LUA -DDYNAMIC_LUA_DLL=\"lua$(LUA_VER).dll\" |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
382 else |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
383 EXTRA_LIBS += $(LUA)/lib/lua$(LUA_VER).lib |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
384 endif |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
385 endif |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
386 |
966a5609669e
Added Lua interfae. (Luis Carvalho)
Bram Moolenaar <bram@vim.org>
parents:
2309
diff
changeset
|
387 ############################## |
7 | 388 ifeq (yes, $(GETTEXT)) |
389 DEFINES += -DDYNAMIC_GETTEXT | |
390 endif | |
391 | |
392 ############################## | |
393 ifeq (yes, $(ICONV)) | |
394 DEFINES += -DDYNAMIC_ICONV | |
395 endif | |
396 | |
397 ############################## | |
398 ifeq (yes, $(MBYTE)) | |
399 DEFINES += -DFEAT_MBYTE | |
400 endif | |
401 | |
402 ############################## | |
403 ifeq (yes, $(IME)) | |
404 DEFINES += -DFEAT_MBYTE_IME | |
405 | |
406 ifndef DYNAMIC_IME | |
407 DYNAMIC_IME = yes | |
408 endif | |
409 | |
410 ifeq (yes, $(DYNAMIC_IME)) | |
411 DEFINES += -DDYNAMIC_IME | |
412 else | |
413 EXTRA_LIBS += -limm32 | |
414 endif | |
415 endif | |
416 | |
417 ############################## | |
418 ifeq (yes, $(DEBUG)) | |
419 DEFINES += -DDEBUG | |
420 INCLUDES += -g -fstack-check | |
421 DEBUG_SUFFIX = d | |
422 else | |
423 | |
424 ifeq ($(OPTIMIZE), SIZE) | |
425 OPTFLAG = -Os | |
426 else | |
427 ifeq ($(OPTIMIZE), MAXSPEED) | |
39 | 428 OPTFLAG = -O3 -fomit-frame-pointer -freg-struct-return |
7 | 429 else |
430 OPTFLAG = -O2 | |
431 endif | |
432 endif | |
433 | |
434 # A bug in the GCC <= 3.2 optimizer can cause a crash. The | |
435 # following option removes the problem optimization. | |
436 OPTFLAG += -fno-strength-reduce | |
437 | |
438 INCLUDES += -s | |
439 | |
440 endif | |
441 | |
442 ############################## | |
443 # USEDLL=yes will build a Cygwin32 executable that relies on cygwin1.dll. | |
444 # USEDLL=no will build a Mingw32 executable with no extra dll dependencies. | |
445 ############################## | |
446 ifeq (yes, $(USEDLL)) | |
447 DEFINES += -D_MAX_PATH=256 -D__CYGWIN__ | |
448 endif | |
449 | |
450 ############################## | |
451 ifeq (yes, $(POSTSCRIPT)) | |
452 DEFINES += -DMSWINPS | |
453 endif | |
454 | |
455 ############################## | |
456 ifeq (yes, $(CSCOPE)) | |
457 DEFINES += -DFEAT_CSCOPE | |
458 EXTRA_OBJS += $(OUTDIR)/if_cscope.o | |
459 endif | |
460 | |
461 ############################## | |
12 | 462 ifeq ($(GUI),yes) |
463 | |
464 ############################## | |
7 | 465 ifeq (yes, $(NETBEANS)) |
12 | 466 # Only allow NETBEANS for a GUI build. |
7 | 467 DEFINES += -DFEAT_NETBEANS_INTG |
185 | 468 EXTRA_OBJS += $(OUTDIR)/netbeans.o |
7 | 469 EXTRA_LIBS += -lwsock32 |
470 | |
12 | 471 ifeq (yes, $(NBDEBUG)) |
7 | 472 DEFINES += -DNBDEBUG |
473 NBDEBUG_DEP = nbdebug.h nbdebug.c | |
474 endif | |
475 | |
476 endif | |
477 | |
478 ############################## | |
6110 | 479 ifeq (yes, $(DIRECTX)) |
480 # Only allow DIRECTX for a GUI build. | |
481 DEFINES += -DFEAT_DIRECTX -DDYNAMIC_DIRECTX | |
482 EXTRA_OBJS += $(OUTDIR)/gui_dwrite.o | |
483 EXTRA_LIBS += -ld2d1 -ldwrite | |
484 USE_STDCPLUS = yes | |
485 endif | |
486 | |
487 ############################## | |
7 | 488 ifdef XPM |
12 | 489 # Only allow XPM for a GUI build. |
7 | 490 DEFINES += -DFEAT_XPM_W32 |
491 INCLUDES += -I$(XPM)/include | |
492 EXTRA_OBJS += $(OUTDIR)/xpm_w32.o | |
493 EXTRA_LIBS += -L$(XPM)/lib -lXpm | |
494 endif | |
495 | |
496 ############################## | |
497 EXE = gvim$(DEBUG_SUFFIX).exe | |
498 OUTDIR = gobj$(DEBUG_SUFFIX) | |
499 DEFINES += -DFEAT_GUI_W32 -DFEAT_CLIPBOARD | |
185 | 500 EXTRA_OBJS += $(OUTDIR)/gui.o $(OUTDIR)/gui_w32.o $(OUTDIR)/gui_beval.o $(OUTDIR)/os_w32exe.o |
435 | 501 EXTRA_LIBS += -mwindows -lcomctl32 -lversion |
7 | 502 else |
503 EXE = vim$(DEBUG_SUFFIX).exe | |
504 OUTDIR = obj$(DEBUG_SUFFIX) | |
505 LIBS += -luser32 -lgdi32 -lcomdlg32 | |
506 endif | |
507 | |
508 ############################## | |
12 | 509 ifeq (yes, $(OLE)) |
510 DEFINES += -DFEAT_OLE | |
511 EXTRA_OBJS += $(OUTDIR)/if_ole.o | |
4137 | 512 EXTRA_LIBS += -loleaut32 |
6110 | 513 USE_STDCPLUS = yes |
12 | 514 endif |
515 | |
516 ############################## | |
7 | 517 ifneq (sh.exe, $(SHELL)) |
518 DEL = rm | |
106 | 519 MKDIR = mkdir -p |
7 | 520 DIRSLASH = / |
521 else | |
522 DEL = del | |
106 | 523 MKDIR = mkdir |
7 | 524 DIRSLASH = \\ |
525 endif | |
526 | |
6110 | 527 ############################## |
528 ifeq (yes, $(USE_STDCPLUS)) | |
529 ifeq (yes, $(STATIC_STDCPLUS)) | |
530 EXTRA_LIBS += -Wl,-Bstatic -lstdc++ -Wl,-Bdynamic | |
531 else | |
532 EXTRA_LIBS += -lstdc++ | |
533 endif | |
534 endif | |
535 | |
7 | 536 #>>>>> end of choices |
537 ########################################################################### | |
538 | |
539 INCL = vim.h globals.h option.h keymap.h macros.h ascii.h term.h os_win32.h \ | |
540 structs.h version.h | |
541 | |
542 CFLAGS = $(OPTFLAG) $(DEFINES) $(INCLUDES) | |
543 | |
544 RCFLAGS = -O coff $(DEFINES) | |
545 | |
546 OBJ = \ | |
2192
40edf1be1cd8
Add blowfish and sha256 source files to more Makefiles.
Bram Moolenaar <bram@vim.org>
parents:
2088
diff
changeset
|
547 $(OUTDIR)/blowfish.o \ |
7 | 548 $(OUTDIR)/buffer.o \ |
549 $(OUTDIR)/charset.o \ | |
6126 | 550 $(OUTDIR)/crypt.o \ |
551 $(OUTDIR)/crypt_zip.o \ | |
7 | 552 $(OUTDIR)/diff.o \ |
553 $(OUTDIR)/digraph.o \ | |
554 $(OUTDIR)/edit.o \ | |
555 $(OUTDIR)/eval.o \ | |
556 $(OUTDIR)/ex_cmds.o \ | |
557 $(OUTDIR)/ex_cmds2.o \ | |
558 $(OUTDIR)/ex_docmd.o \ | |
559 $(OUTDIR)/ex_eval.o \ | |
560 $(OUTDIR)/ex_getln.o \ | |
561 $(OUTDIR)/fileio.o \ | |
562 $(OUTDIR)/fold.o \ | |
563 $(OUTDIR)/getchar.o \ | |
440 | 564 $(OUTDIR)/hardcopy.o \ |
800 | 565 $(OUTDIR)/hashtab.o \ |
7 | 566 $(OUTDIR)/main.o \ |
567 $(OUTDIR)/mark.o \ | |
568 $(OUTDIR)/memfile.o \ | |
569 $(OUTDIR)/memline.o \ | |
570 $(OUTDIR)/menu.o \ | |
571 $(OUTDIR)/message.o \ | |
572 $(OUTDIR)/misc1.o \ | |
573 $(OUTDIR)/misc2.o \ | |
574 $(OUTDIR)/move.o \ | |
575 $(OUTDIR)/mbyte.o \ | |
576 $(OUTDIR)/normal.o \ | |
577 $(OUTDIR)/ops.o \ | |
578 $(OUTDIR)/option.o \ | |
579 $(OUTDIR)/os_win32.o \ | |
580 $(OUTDIR)/os_mswin.o \ | |
4168 | 581 $(OUTDIR)/winclip.o \ |
7 | 582 $(OUTDIR)/pathdef.o \ |
800 | 583 $(OUTDIR)/popupmnu.o \ |
7 | 584 $(OUTDIR)/quickfix.o \ |
585 $(OUTDIR)/regexp.o \ | |
586 $(OUTDIR)/screen.o \ | |
587 $(OUTDIR)/search.o \ | |
2192
40edf1be1cd8
Add blowfish and sha256 source files to more Makefiles.
Bram Moolenaar <bram@vim.org>
parents:
2088
diff
changeset
|
588 $(OUTDIR)/sha256.o \ |
226 | 589 $(OUTDIR)/spell.o \ |
7 | 590 $(OUTDIR)/syntax.o \ |
591 $(OUTDIR)/tag.o \ | |
592 $(OUTDIR)/term.o \ | |
593 $(OUTDIR)/ui.o \ | |
594 $(OUTDIR)/undo.o \ | |
595 $(OUTDIR)/version.o \ | |
596 $(OUTDIR)/vimrc.o \ | |
597 $(OUTDIR)/window.o \ | |
598 $(EXTRA_OBJS) | |
599 | |
600 all: $(EXE) xxd/xxd.exe vimrun.exe install.exe uninstal.exe GvimExt/gvimext.dll | |
601 | |
602 # According to the Cygwin doc 1.2 FAQ, kernel32 should not be specified for | |
603 # linking unless calling ld directly. | |
604 # See /usr/doc/cygwin-doc-1.2/html/faq_toc.html#TOC93 for more information. | |
605 $(EXE): $(OUTDIR) $(OBJ) | |
606 $(CC) $(CFLAGS) -o $(EXE) $(OBJ) $(LIBS) -luuid -lole32 $(EXTRA_LIBS) | |
607 | |
608 xxd/xxd.exe: xxd/xxd.c | |
2088
4ec11bb387a5
updated for version 7.2.372
Bram Moolenaar <bram@zimbu.org>
parents:
1951
diff
changeset
|
609 $(MAKE) -C xxd -f Make_cyg.mak CC=$(CC) USEDLL=$(USEDLL) |
7 | 610 |
611 GvimExt/gvimext.dll: GvimExt/gvimext.cpp GvimExt/gvimext.rc GvimExt/gvimext.h | |
3110 | 612 $(MAKE) -C GvimExt -f Make_cyg.mak CROSS_COMPILE=$(CROSS_COMPILE) |
7 | 613 |
614 vimrun.exe: vimrun.c | |
615 $(CC) $(CFLAGS) -o vimrun.exe vimrun.c $(LIBS) | |
616 | |
617 install.exe: dosinst.c | |
618 $(CC) $(CFLAGS) -o install.exe dosinst.c $(LIBS) -luuid -lole32 | |
619 | |
620 uninstal.exe: uninstal.c | |
621 $(CC) $(CFLAGS) -o uninstal.exe uninstal.c $(LIBS) | |
622 | |
623 $(OUTDIR): | |
106 | 624 $(MKDIR) $(OUTDIR) |
7 | 625 |
626 tags: | |
627 command /c ctags *.c $(INCL) | |
628 | |
629 clean: | |
630 -$(DEL) $(OUTDIR)$(DIRSLASH)*.o | |
631 -rmdir $(OUTDIR) | |
84 | 632 -$(DEL) $(EXE) vimrun.exe install.exe uninstal.exe |
7 | 633 ifdef PERL |
634 -$(DEL) if_perl.c | |
635 endif | |
1951 | 636 ifdef MZSCHEME |
637 -$(DEL) mzscheme_base.c | |
638 endif | |
7 | 639 -$(DEL) pathdef.c |
640 $(MAKE) -C xxd -f Make_cyg.mak clean | |
3110 | 641 $(MAKE) -C GvimExt -f Make_cyg.mak clean |
7 | 642 |
84 | 643 distclean: clean |
644 -$(DEL) obj$(DIRSLASH)*.o | |
645 -rmdir obj | |
646 -$(DEL) gobj$(DIRSLASH)*.o | |
647 -rmdir gobj | |
648 -$(DEL) objd$(DIRSLASH)*.o | |
649 -rmdir objd | |
650 -$(DEL) gobjd$(DIRSLASH)*.o | |
651 -rmdir gobjd | |
652 -$(DEL) *.exe | |
653 | |
7 | 654 ########################################################################### |
655 | |
656 $(OUTDIR)/%.o : %.c $(INCL) | |
657 $(CC) -c $(CFLAGS) $< -o $@ | |
658 | |
659 $(OUTDIR)/ex_docmd.o: ex_docmd.c $(INCL) ex_cmds.h | |
660 $(CC) -c $(CFLAGS) ex_docmd.c -o $(OUTDIR)/ex_docmd.o | |
661 | |
662 $(OUTDIR)/ex_eval.o: ex_eval.c $(INCL) ex_cmds.h | |
663 $(CC) -c $(CFLAGS) ex_eval.c -o $(OUTDIR)/ex_eval.o | |
664 | |
4041 | 665 $(OUTDIR)/gui_w32.o: gui_w32.c gui_w48.c $(INCL) |
666 $(CC) -c $(CFLAGS) gui_w32.c -o $(OUTDIR)/gui_w32.o | |
667 | |
6110 | 668 $(OUTDIR)/gui_dwrite.o: gui_dwrite.cpp $(INCL) gui_dwrite.h |
669 $(CC) -c $(CFLAGS) gui_dwrite.cpp -o $(OUTDIR)/gui_dwrite.o | |
670 | |
7 | 671 $(OUTDIR)/if_cscope.o: if_cscope.c $(INCL) if_cscope.h |
672 $(CC) -c $(CFLAGS) if_cscope.c -o $(OUTDIR)/if_cscope.o | |
673 | |
674 $(OUTDIR)/if_ole.o: if_ole.cpp $(INCL) | |
1413 | 675 $(CC) -c $(CFLAGS) if_ole.cpp -o $(OUTDIR)/if_ole.o |
7 | 676 |
4724
450e13fe1621
updated for version 7.3.1109
Bram Moolenaar <bram@vim.org>
parents:
4444
diff
changeset
|
677 $(OUTDIR)/if_python.o : if_python.c if_py_both.h $(INCL) |
2329
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
678 $(CC) -c $(CFLAGS) -I$(PYTHON)/include $< -o $@ |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
679 |
4724
450e13fe1621
updated for version 7.3.1109
Bram Moolenaar <bram@vim.org>
parents:
4444
diff
changeset
|
680 $(OUTDIR)/if_python3.o : if_python3.c if_py_both.h $(INCL) |
2329
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
681 $(CC) -c $(CFLAGS) -I$(PYTHON3)/include $< -o $@ |
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
682 |
7 | 683 if_perl.c: if_perl.xs typemap |
84 | 684 $(PERL)/bin/perl `cygpath -d $(PERL)/lib/ExtUtils/xsubpp` \ |
685 -prototypes -typemap \ | |
686 `cygpath -d $(PERL)/lib/ExtUtils/typemap` if_perl.xs > $@ | |
7 | 687 |
688 $(OUTDIR)/if_perl.o: if_perl.c $(INCL) | |
689 ifeq (yes, $(USEDLL)) | |
690 $(CC) -c $(CFLAGS) -I/usr/include/mingw -D__MINGW32__ if_perl.c -o $(OUTDIR)/if_perl.o | |
691 endif | |
692 | |
693 $(OUTDIR)/if_ruby.o: if_ruby.c $(INCL) | |
694 ifeq (16, $(RUBY_VER)) | |
695 $(CC) -c $(CFLAGS) -U_WIN32 if_ruby.c -o $(OUTDIR)/if_ruby.o | |
696 endif | |
697 | |
698 $(OUTDIR)/netbeans.o: netbeans.c $(INCL) $(NBDEBUG_DEP) | |
699 $(CC) -c $(CFLAGS) netbeans.c -o $(OUTDIR)/netbeans.o | |
700 | |
4444 | 701 $(OUTDIR)/regexp.o: regexp.c regexp_nfa.c $(INCL) |
702 $(CC) -c $(CFLAGS) regexp.c -o $(OUTDIR)/regexp.o | |
703 | |
1951 | 704 $(OUTDIR)/if_mzsch.o: if_mzsch.c $(INCL) if_mzsch.h $(MZ_EXTRA_DEP) |
705 $(CC) -c $(CFLAGS) if_mzsch.c -o $(OUTDIR)/if_mzsch.o | |
706 | |
7 | 707 $(OUTDIR)/vimrc.o: vim.rc version.h gui_w32_rc.h |
708 $(RC) $(RCFLAGS) vim.rc -o $(OUTDIR)/vimrc.o | |
709 | |
1951 | 710 mzscheme_base.c: |
711 $(MZSCHEME)/mzc --c-mods mzscheme_base.c ++lib scheme/base | |
712 | |
7 | 713 pathdef.c: $(INCL) |
714 ifneq (sh.exe, $(SHELL)) | |
715 @echo creating pathdef.c | |
716 @echo '/* pathdef.c */' > pathdef.c | |
717 @echo '#include "vim.h"' >> pathdef.c | |
718 @echo 'char_u *default_vim_dir = (char_u *)"$(VIMRCLOC)";' >> pathdef.c | |
719 @echo 'char_u *default_vimruntime_dir = (char_u *)"$(VIMRUNTIMEDIR)";' >> pathdef.c | |
720 @echo 'char_u *all_cflags = (char_u *)"$(CC) $(CFLAGS)";' >> pathdef.c | |
721 @echo 'char_u *all_lflags = (char_u *)"$(CC) -s -o $(EXE) $(LIBS) -luuid -lole32 $(EXTRA_LIBS)";' >> pathdef.c | |
722 @echo 'char_u *compiled_user = (char_u *)"$(USERNAME)";' >> pathdef.c | |
723 @echo 'char_u *compiled_sys = (char_u *)"$(USERDOMAIN)";' >> pathdef.c | |
724 else | |
725 @echo creating pathdef.c | |
726 @echo /* pathdef.c */ > pathdef.c | |
727 @echo #include "vim.h" >> pathdef.c | |
728 @echo char_u *default_vim_dir = (char_u *)"$(VIMRCLOC)"; >> pathdef.c | |
729 @echo char_u *default_vimruntime_dir = (char_u *)"$(VIMRUNTIMEDIR)"; >> pathdef.c | |
730 @echo char_u *all_cflags = (char_u *)"$(CC) $(CFLAGS)"; >> pathdef.c | |
731 @echo char_u *all_lflags = (char_u *)"$(CC) -s -o $(EXE) $(LIBS) -luuid -lole32 $(EXTRA_LIBS)"; >> pathdef.c | |
732 @echo char_u *compiled_user = (char_u *)"$(USERNAME)"; >> pathdef.c | |
733 @echo char_u *compiled_sys = (char_u *)"$(USERDOMAIN)"; >> pathdef.c | |
734 endif | |
2329
ad2889f48843
Added support for Python 3. (Roland Puntaier)
Bram Moolenaar <bram@vim.org>
parents:
2320
diff
changeset
|
735 |