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