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