X-Git-Url: http://sjero.net/git/?a=blobdiff_plain;f=windows%2FMakefile.watcom;h=bbd5a89ec69358cd3161cfae1be2fac9f922bc47;hb=713ecfdca60257c645c6be6ae47b872b59fc050f;hp=01a66a7a896fb13c33a44f67e2d55544820a41ff;hpb=87bdff25cf6c7b416334da8626763c997bea817d;p=wget diff --git a/windows/Makefile.watcom b/windows/Makefile.watcom index 01a66a7a..bbd5a89e 100644 --- a/windows/Makefile.watcom +++ b/windows/Makefile.watcom @@ -7,10 +7,13 @@ CC=wcc386 /zq LINK=wlink +# +# Note: this will wipe anything in the env.var PATH ! +# .BEFORE @SET INCLUDE=$(%WATCOM)\h;$(%WATCOM)\h\nt;. -LFLAGS=op q sys nt op st=32767 op vers=1.7 op map op de 'GNU wget 1.7dev' de dw op symf +LFLAGS=op q sys nt op st=32767 op map op de 'GNU Wget' de dw op symf # # op q : quiet ! # sys nt : producing an NT app @@ -22,12 +25,12 @@ LFLAGS=op q sys nt op st=32767 op vers=1.7 op map op de 'GNU wget 1.7dev' de dw # op symf : place debug info in a separate wget.sym # -CFLAGS=/zp4 /w4 /fpd /5s /fp5 /bm /mf /bt=nt /DWINDOWS /DHAVE_CONFIG_H +CFLAGS=/zp4 /w4 /fpd /5s /fp5 /bm /mf /bt=nt /I. /DWINDOWS /DHAVE_CONFIG_H # ^^^^^^^^ wget will run on NT. We can safely assume a Pentium :-) # /zp4= pack structure members with this alignment # /d1 = line number debug info # /w4 = warning level -# /fpd= ??? no such switch ! +# /fpd= Pentium floatingpoint bug workaround # /5s = Pentium stack-based calling # /fp5= Pentium floating point # /bm = build multi-threaded @@ -48,42 +51,11 @@ CFLAGS+= /os /d2 #CFLAGS+= /DDEBUG_MALLOC # ^^-- mind the gap !! -# -# The trouble: dependencies need to be space-separated (exe : obj1 obj2) -# wlink wants them comma-separated ( wlink FILE obj1,obj2 ) -# The trick : Use wmake's "immediate expansion" feautre ( $+ turns it on, -# end-of-line and $_ turns it off ) to construct -# Background : wmake expands macros in macro definitions at the place of -# the macro call (GNU make's = behaviour) -# $+ changes this behaviour to expand the macros at the -# place of the macro *definition* (kinda like gmake's := does) -# -# See the "Macros" topic in the Watcom Tools Guide -# - -# -# Add new object files to OBJS, with $_ appended -# Note: There MUST NOT be a $_ on the last one !! -# & is the line continuation character (also shouldn't be present at the end) -# -OBJS = cmpt.obj$_ connect.obj$_ cookies.obj$_ fnmatch.obj$_ ftp.obj$_ ftp-basic.obj$_ & - ftp-ls.obj$_ ftp-opie.obj$_ getopt.obj$_ hash.obj$_ headers.obj$_ host.obj$_ html-parse.obj$_ html-url.obj$_ & - http.obj$_ init.obj$_ log.obj$_ main.obj$_ md5.obj$_ netrc.obj$_ rbuf.obj$_ & - recur.obj$_ retr.obj$_ safe-ctype.obj$_ url.obj$_ utils.obj$_ version.obj$_ mswindows.obj - - -# -# For LINKOBJS, $_ is defined as a comma -# -_=, -LINKOBJS=FILE $+$(OBJS)$- - -# -# Empty $_ again. OBJS can now be used as the dependency list for wget.exe -# -_= - - +OBJS = cmpt.obj convert.obj connect.obj cookies.obj ftp.obj ftp-basic.obj & + ftp-ls.obj ftp-opie.obj getopt.obj hash.obj host.obj html-parse.obj html-url.obj & + http.obj init.obj log.obj main.obj gen-md5.obj gnu-md5.obj netrc.obj progress.obj & + recur.obj res.obj retr.obj safe-ctype.obj url.obj utils.obj version.obj mswindows.obj & + xmalloc.obj LIBFILES = # @@ -100,8 +72,13 @@ all : config.h $(BINNAME) .SYMBOLIC config.h : ..\windows\config.h.ms copy $[@ $^@ +# +# Note: this will pass all the OBJ files to wlink, +# resulting in a very long command line (410 chars, last I counted) +# This might fail on Win9x (works with NT's cmd.exe) +# $(BINNAME): $(OBJS) Makefile - $(LINK) $(LFLAGS) NAME $(BINNAME) $(LINKOBJS) $(LIBPATH) $(LIBFILES) + $(LINK) $(LFLAGS) NAME $(BINNAME) FILE { $(OBJS) } $(LIBPATH) $(LIBFILES) # @@ -113,3 +90,6 @@ $(BINNAME): $(OBJS) Makefile .c.obj: .AUTODEPEND $(CC) $(CFLAGS) $[@ +.c.i: .AUTODEPEND + $(CC) $(CFLAGS) -fo=$@ /Pc $[@ +