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