diff options
-rw-r--r-- | win32/Makefile | 121 | ||||
-rw-r--r-- | win32/config.gc | 2 | ||||
-rw-r--r-- | win32/makefile.mk | 272 | ||||
-rw-r--r-- | win32/makegcc.mk | 531 | ||||
-rw-r--r-- | win32/win32.h | 3 |
5 files changed, 240 insertions, 689 deletions
diff --git a/win32/Makefile b/win32/Makefile index 191e5841e5..968b1df3ef 100644 --- a/win32/Makefile +++ b/win32/Makefile @@ -87,23 +87,26 @@ LIBFILES = oldnames.lib kernel32.lib user32.lib gdi32.lib \ oleaut32.lib netapi32.lib uuid.lib wsock32.lib mpr.lib winmm.lib \ version.lib odbc32.lib odbccp32.lib -CFLAGS = -nologo -W3 $(INCLUDES) $(DEFINES) $(LOCDEFS) $(PCHFLAGS) $(OPTIMIZE) +CFLAGS = -nologo -Gf -W3 $(INCLUDES) $(DEFINES) $(LOCDEFS) $(PCHFLAGS) $(OPTIMIZE) LINK_FLAGS = -nologo $(LINK_DBG) -machine:$(PROCESSOR_ARCHITECTURE) OBJOUT_FLAG = -Fo +EXEOUT_FLAG = -Fe #################### do not edit below this line ####################### ############# NO USER-SERVICEABLE PARTS BEYOND THIS POINT ############## +o = .obj + # # Rules # -.SUFFIXES : -.SUFFIXES : .c .obj .dll .lib .exe -.c.obj: +.SUFFIXES : .c $(o) .dll .lib .exe + +.c$(o): $(CC) -c $(CFLAGS) $(OBJOUT_FLAG)$@ $< -.obj.dll: +$(o).dll: $(LINK32) -dll -subsystem:windows -implib:$(*B).lib -def:$(*B).def \ -out:$@ $(LINK_FLAGS) $(LIBFILES) $< $(LIBPERL) @@ -171,48 +174,48 @@ CORE_C= ..\av.c \ ..\util.c \ ..\malloc.c -CORE_OBJ= ..\av.obj \ - ..\deb.obj \ - ..\doio.obj \ - ..\doop.obj \ - ..\dump.obj \ - ..\globals.obj \ - ..\gv.obj \ - ..\hv.obj \ - ..\mg.obj \ - ..\op.obj \ - ..\perl.obj \ - ..\perlio.obj \ - ..\perly.obj \ - ..\pp.obj \ - ..\pp_ctl.obj \ - ..\pp_hot.obj \ - ..\pp_sys.obj \ - ..\regcomp.obj \ - ..\regexec.obj \ - ..\run.obj \ - ..\scope.obj \ - ..\sv.obj \ - ..\taint.obj \ - ..\toke.obj \ - ..\universal.obj\ - ..\util.obj \ - ..\malloc.obj +CORE_OBJ= ..\av$(o) \ + ..\deb$(o) \ + ..\doio$(o) \ + ..\doop$(o) \ + ..\dump$(o) \ + ..\globals$(o) \ + ..\gv$(o) \ + ..\hv$(o) \ + ..\mg$(o) \ + ..\op$(o) \ + ..\perl$(o) \ + ..\perlio$(o) \ + ..\perly$(o) \ + ..\pp$(o) \ + ..\pp_ctl$(o) \ + ..\pp_hot$(o) \ + ..\pp_sys$(o) \ + ..\regcomp$(o) \ + ..\regexec$(o) \ + ..\run$(o) \ + ..\scope$(o) \ + ..\sv$(o) \ + ..\taint$(o) \ + ..\toke$(o) \ + ..\universal$(o)\ + ..\util$(o) \ + ..\malloc$(o) WIN32_C = perllib.c \ win32.c \ win32sck.c \ win32thread.c -WIN32_OBJ = win32.obj \ - win32sck.obj \ - win32thread.obj +WIN32_OBJ = win32$(o) \ + win32sck$(o) \ + win32thread$(o) -PERL95_OBJ = perl95.obj \ - win32mt.obj \ - win32sckmt.obj +PERL95_OBJ = perl95$(o) \ + win32mt$(o) \ + win32sckmt$(o) -DLL_OBJ = perllib.obj $(DYNALOADER).obj +DLL_OBJ = perllib$(o) $(DYNALOADER)$(o) CORE_H = ..\av.h \ ..\cop.h \ @@ -292,20 +295,20 @@ POD2TEXT=$(PODDIR)\pod2text all: $(PERLEXE) $(PERL95EXE) $(GLOBEXE) $(DYNALOADMODULES) $(MINIMOD) $(GLOBBAT) -$(DYNALOADER).obj : $(DYNALOADER).c $(CORE_H) $(EXTDIR)\DynaLoader\dlutils.c +$(DYNALOADER)$(o) : $(DYNALOADER).c $(CORE_H) $(EXTDIR)\DynaLoader\dlutils.c #------------------------------------------------------------ -$(GLOBEXE): perlglob.obj +$(GLOBEXE): perlglob$(o) $(LINK32) $(LINK_FLAGS) $(LIBFILES) -out:$@ -subsystem:$(SUBSYS) \ - perlglob.obj setargv.obj + perlglob$(o) setargv$(o) $(GLOBBAT) : ..\lib\File\DosGlob.pm $(MINIPERL) $(MINIPERL) $(PL2BAT) - < ..\lib\File\DosGlob.pm > $(GLOBBAT) -perlglob.obj : perlglob.c +perlglob$(o) : perlglob.c -..\miniperlmain.obj : ..\miniperlmain.c $(CORE_H) +..\miniperlmain$(o) : ..\miniperlmain.c $(CORE_H) config.w32 : $(CFGSH_TMPL) copy $(CFGSH_TMPL) config.w32 @@ -340,9 +343,9 @@ $(CONFIGPM) : $(MINIPERL) ..\config.sh config_h.PL ..\minimod.pl $(MINIPERL) -I..\lib config_h.PL || $(MAKE) CCTYPE=$(CCTYPE) \ RUNTIME=$(RUNTIME) CFG=$(CFG) $(CONFIGPM) -$(MINIPERL) : ..\miniperlmain.obj $(CORE_OBJ) $(WIN32_OBJ) +$(MINIPERL) : ..\miniperlmain$(o) $(CORE_OBJ) $(WIN32_OBJ) $(LINK32) -subsystem:console -out:$@ @<< - $(LINK_FLAGS) $(LIBFILES) ..\miniperlmain.obj $(CORE_OBJ) $(WIN32_OBJ) + $(LINK_FLAGS) $(LIBFILES) ..\miniperlmain$(o) $(CORE_OBJ) $(WIN32_OBJ) << $(WIN32_OBJ) : $(CORE_H) @@ -369,12 +372,12 @@ $(MINIMOD) : $(MINIPERL) ..\minimod.pl perlmain.c : runperl.c copy runperl.c perlmain.c -perlmain.obj : perlmain.c +perlmain$(o) : perlmain.c $(CC) $(CFLAGS) -UPERLDLL -c perlmain.c -$(PERLEXE): $(PERLDLL) $(CONFIGPM) perlmain.obj +$(PERLEXE): $(PERLDLL) $(CONFIGPM) perlmain$(o) $(LINK32) -subsystem:console -out:perl.exe $(LINK_FLAGS) $(LIBFILES) \ - perlmain.obj $(WINIOMAYBE) $(PERLIMPLIB) + perlmain$(o) $(WINIOMAYBE) $(PERLIMPLIB) copy perl.exe $@ del perl.exe copy splittree.pl .. @@ -383,14 +386,14 @@ $(PERLEXE): $(PERLDLL) $(CONFIGPM) perlmain.obj perl95.c : runperl.c copy runperl.c perl95.c -perl95.obj : perl95.c +perl95$(o) : perl95.c $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c perl95.c -win32sckmt.obj : win32sck.c - $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32sckmt.obj win32sck.c +win32sckmt$(o) : win32sck.c + $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32sckmt$(o) win32sck.c -win32mt.obj : win32.c - $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32mt.obj win32.c +win32mt$(o) : win32.c + $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32mt$(o) win32.c $(PERL95EXE): $(PERLDLL) $(CONFIGPM) $(PERL95_OBJ) $(LINK32) -subsystem:console -out:perl95.exe $(LINK_FLAGS) $(LIBFILES) \ @@ -488,7 +491,7 @@ distclean: clean -rmdir /s /q ..\lib\auto -rmdir /s /q ..\lib\CORE cd $(EXTDIR) - -del /s *.lib *.def *.map *.bs Makefile *.obj pm_to_blib + -del /s *.lib *.def *.map *.bs Makefile *$(o) pm_to_blib cd ..\win32 install : all doc utils @@ -535,10 +538,10 @@ test-notty : test-prep cd ..\win32 clean : - -@erase miniperlmain.obj + -@erase miniperlmain$(o) -@erase $(MINIPERL) - -@erase perlglob.obj - -@erase perlmain.obj + -@erase perlglob$(o) + -@erase perlmain$(o) -@erase config.w32 -@erase /f config.h -@erase $(GLOBEXE) @@ -547,7 +550,7 @@ clean : -@erase $(CORE_OBJ) -@erase $(WIN32_OBJ) -@erase $(DLL_OBJ) - -@erase ..\*.obj ..\*.lib ..\*.exp *.obj *.lib *.exp + -@erase ..\*$(o) ..\*.lib ..\*.exp *$(o) *.lib *.exp -@erase ..\t\*.exe ..\t\*.dll ..\t\*.bat -@erase *.ilk -@erase *.pdb diff --git a/win32/config.gc b/win32/config.gc index b267f548ca..c9b0b2ab09 100644 --- a/win32/config.gc +++ b/win32/config.gc @@ -59,7 +59,7 @@ byteorder='1234' c='' castflags='0' cat='type' -cccdlflags='-dll' +cccdlflags=' ' ccdlflags=' ' cf_by='nobody' cf_email='nobody@no.where.net' diff --git a/win32/makefile.mk b/win32/makefile.mk index bddf16bab7..2ab571a91d 100644 --- a/win32/makefile.mk +++ b/win32/makefile.mk @@ -1,6 +1,9 @@ # -# Makefile to build perl on Windowns NT using Microsoft NMAKE. -# +# Makefile to build perl on Windowns NT using DMAKE. +# Supported compilers: +# Visual C++ 2.0 thro 5.0 +# Borland C++ 5.02 +# Mingw32-0.1.4 with gcc-2.7.2 # # This is set up to build a perl.exe that runs off a shared library # (perl.dll). Also makes individual DLLs for the XS extensions. @@ -9,41 +12,46 @@ # # Set these to wherever you want "nmake install" to put your # newly built perl. -INST_DRV=c: -INST_TOP=$(INST_DRV)\perl5004.5x -BUILDOPT=-DUSE_THREADS -#BUILDOPT=-DMULTIPLICITY -#BUILDOPT=-DMULTIPLICITY -DUSE_THREADS -#BUILDOPT=-DPERL_GLOBAL_STRUCT -DMULTIPLICITY +INST_DRV *= c: +INST_TOP *= $(INST_DRV)\perl5004.5x + +# +# +BUILDOPT *= -DUSE_THREADS +#BUILDOPT *= -DMULTIPLICITY +#BUILDOPT *=-DMULTIPLICITY -DUSE_THREADS +#BUILDOPT *=-DPERL_GLOBAL_STRUCT -DMULTIPLICITY # -DUSE_PERLIO -D__STDC__=1 -DUSE_SFIO -DI_SFIO -I\sfio97\include # -# uncomment one if you are using Visual C++ 2.x or Borland -# comment out both if you are using Visual C++ 4.x and above -#CCTYPE=MSVC20 -CCTYPE=BORLAND +# uncomment one +#CCTYPE *= MSVC20 +#CCTYPE *= MSVC +CCTYPE *= BORLAND +#CCTYPE *= GCC # # uncomment next line if you want debug version of perl (big,slow) -#CFG=Debug +#CFG *= Debug # # set the install locations of the compiler include/libraries -#CCHOME = f:\msdev\vc -CCHOME = C:\bc5 -CCINCDIR = $(CCHOME)\include -CCLIBDIR = $(CCHOME)\lib +#CCHOME *= f:\msdev\vc +CCHOME *= C:\bc5 +#CCHOME *= C:\mingw32 +CCINCDIR *= $(CCHOME)\include +CCLIBDIR *= $(CCHOME)\lib # # set this to point to cmd.exe (only needed if you use some # alternate shell that doesn't grok cmd.exe style commands) -#SHELL = g:\winnt\system32\cmd.exe +#SHELL *= g:\winnt\system32\cmd.exe # # set this to your email address (perl will guess a value from # from your loginname and your hostname, which may not be right) -#EMAIL = +#EMAIL *= ##################### CHANGE THESE ONLY IF YOU MUST ##################### @@ -85,6 +93,43 @@ LINK_DBG = CFLAGS = -w -d -tWM -tWD $(INCLUDES) $(DEFINES) $(LOCDEFS) $(PCHFLAGS) $(OPTIMIZE) LINK_FLAGS = $(LINK_DBG) -L$(CCLIBDIR) OBJOUT_FLAG = -o +EXEOUT_FLAG = -e + +.ELIF "$(CCTYPE)" == "GCC" + +CC = gcc -pipe +LINK32 = gcc +LIB32 = ar +IMPLIB = dlltool + +o = .o + +# +# Options +# +RUNTIME = +INCLUDES = -I.\include -I. -I.. +DEFINES = -DWIN32 $(BUILDOPT) +LOCDEFS = -DPERLDLL -DPERL_CORE +SUBSYS = console +LIBC = -lcrtdll +LIBFILES = -ladvapi32 -luser32 -lwsock32 -lmingw32 -lgcc -lmoldname $(LIBC) \ + -lkernel32 + +WINIOMAYBE = + +.IF "$(CFG)" == "Debug" +OPTIMIZE = -g -O2 $(RUNTIME) -DDEBUGGING +LINK_DBG = -g +.ELSE +OPTIMIZE = -g -O2 $(RUNTIME) +LINK_DBG = +.ENDIF + +CFLAGS = $(INCLUDES) $(DEFINES) $(LOCDEFS) $(OPTIMIZE) +LINK_FLAGS = $(LINK_DBG) -L$(CCLIBDIR) +OBJOUT_FLAG = -o +EXEOUT_FLAG = -o .ELSE @@ -127,41 +172,47 @@ OPTIMIZE = -Od $(RUNTIME) -DNDEBUG LINK_DBG = -release .ENDIF +.IMPORT .IGNORE : PROCESSOR_ARCHITECTURE + +PROCESSOR_ARCHITECTURE *= x86 + # we don't add LIBC here, the compiler do it based on -MD/-MT LIBFILES = oldnames.lib kernel32.lib user32.lib gdi32.lib \ winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib \ oleaut32.lib netapi32.lib uuid.lib wsock32.lib mpr.lib winmm.lib \ version.lib odbc32.lib odbccp32.lib -CFLAGS = -nologo -W3 $(INCLUDES) $(DEFINES) $(LOCDEFS) $(PCHFLAGS) $(OPTIMIZE) +CFLAGS = -nologo -Gf -W3 $(INCLUDES) $(DEFINES) $(LOCDEFS) $(PCHFLAGS) $(OPTIMIZE) LINK_FLAGS = -nologo $(LINK_DBG) -machine:$(PROCESSOR_ARCHITECTURE) OBJOUT_FLAG = -Fo +EXEOUT_FLAG = -Fe .ENDIF #################### do not edit below this line ####################### ############# NO USER-SERVICEABLE PARTS BEYOND THIS POINT ############## +o *= .obj + # # Rules # -.SUFFIXES : -.SUFFIXES : .c .obj .dll .lib .exe -.c.obj: +.SUFFIXES : .c $(o) .dll .lib .exe .a + +.c$(o): $(CC) -c $(CFLAGS) $(OBJOUT_FLAG)$@ $< +$(o).dll: .IF "$(CCTYPE)" == "BORLAND" - -.obj.dll: - $(LINK32) -Tpd -ap $(LINK_FLAGS) c0d32.obj $<,$@,,$(LIBFILES),$(*B).def + $(LINK32) -Tpd -ap $(LINK_FLAGS) c0d32$(o) $<,$@,,$(LIBFILES),$(*B).def $(IMPLIB) $(*B).lib $@ +.ELIF "$(CCTYPE)" == "GCC" + $(LINK32) -o $@ $(LINK_FLAGS) $< $(LIBFILES) + $(IMPLIB) -def $(*B).def $(*B).lib $@ .ELSE - -.obj.dll: $(LINK32) -dll -subsystem:windows -implib:$(*B).lib -def:$(*B).def \ -out:$@ $(LINK_FLAGS) $(LIBFILES) $< $(LIBPERL) - .ENDIF # @@ -189,10 +240,13 @@ GLOBBAT = bin\perlglob.bat .IF "$(CCTYPE)" == "BORLAND" -# Borland wildargs is incompatible with MS setargv CFGSH_TMPL = config.bc CFGH_TMPL = config_H.bc -# Borland's perl.exe will work on W95, so we don't make this + +.ELIF "$(CCTYPE)" == "GCC" + +CFGSH_TMPL = config.gc +CFGH_TMPL = config_H.gc .ELSE @@ -240,48 +294,48 @@ CORE_C= ..\av.c \ ..\util.c \ ..\malloc.c -CORE_OBJ= ..\av.obj \ - ..\deb.obj \ - ..\doio.obj \ - ..\doop.obj \ - ..\dump.obj \ - ..\globals.obj \ - ..\gv.obj \ - ..\hv.obj \ - ..\mg.obj \ - ..\op.obj \ - ..\perl.obj \ - ..\perlio.obj \ - ..\perly.obj \ - ..\pp.obj \ - ..\pp_ctl.obj \ - ..\pp_hot.obj \ - ..\pp_sys.obj \ - ..\regcomp.obj \ - ..\regexec.obj \ - ..\run.obj \ - ..\scope.obj \ - ..\sv.obj \ - ..\taint.obj \ - ..\toke.obj \ - ..\universal.obj\ - ..\util.obj \ - ..\malloc.obj +CORE_OBJ= ..\av$(o) \ + ..\deb$(o) \ + ..\doio$(o) \ + ..\doop$(o) \ + ..\dump$(o) \ + ..\globals$(o) \ + ..\gv$(o) \ + ..\hv$(o) \ + ..\mg$(o) \ + ..\op$(o) \ + ..\perl$(o) \ + ..\perlio$(o) \ + ..\perly$(o) \ + ..\pp$(o) \ + ..\pp_ctl$(o) \ + ..\pp_hot$(o) \ + ..\pp_sys$(o) \ + ..\regcomp$(o) \ + ..\regexec$(o) \ + ..\run$(o) \ + ..\scope$(o) \ + ..\sv$(o) \ + ..\taint$(o) \ + ..\toke$(o) \ + ..\universal$(o)\ + ..\util$(o) \ + ..\malloc$(o) WIN32_C = perllib.c \ win32.c \ win32sck.c \ win32thread.c -WIN32_OBJ = win32.obj \ - win32sck.obj \ - win32thread.obj +WIN32_OBJ = win32$(o) \ + win32sck$(o) \ + win32thread$(o) -PERL95_OBJ = perl95.obj \ - win32mt.obj \ - win32sckmt.obj +PERL95_OBJ = perl95$(o) \ + win32mt$(o) \ + win32sckmt$(o) -DLL_OBJ = perllib.obj $(DYNALOADER).obj +DLL_OBJ = perllib$(o) $(DYNALOADER)$(o) CORE_H = ..\av.h \ ..\cop.h \ @@ -361,26 +415,28 @@ POD2TEXT=$(PODDIR)\pod2text all: $(PERLEXE) $(PERL95EXE) $(GLOBEXE) $(DYNALOADMODULES) $(MINIMOD) $(GLOBBAT) -$(DYNALOADER).obj : $(DYNALOADER).c $(CORE_H) $(EXTDIR)\DynaLoader\dlutils.c +$(DYNALOADER)$(o) : $(DYNALOADER).c $(CORE_H) $(EXTDIR)\DynaLoader\dlutils.c #------------------------------------------------------------ -$(GLOBEXE): perlglob.obj +$(GLOBEXE): perlglob$(o) .IF "$(CCTYPE)" == "BORLAND" $(CC) -c -w -v -tWM -I$(CCINCDIR) perlglob.c - $(LINK32) -Tpe -ap $(LINK_FLAGS) c0x32.obj perlglob.obj \ - $(CCLIBDIR)\32BIT\wildargs.obj,$@,,import32.lib cw32mt.lib, + $(LINK32) -Tpe -ap $(LINK_FLAGS) c0x32$(o) perlglob$(o) \ + $(CCLIBDIR)\32BIT\wildargs$(o),$@,,import32.lib cw32mt.lib, +.ELIF "$(CCTYPE)" == "GCC" + $(LINK32) $(LINK_FLAGS) -o $@ perlglob$(o) $(LIBFILES) .ELSE $(LINK32) $(LINK_FLAGS) $(LIBFILES) -out:$@ -subsystem:$(SUBSYS) \ - perlglob.obj setargv.obj + perlglob$(o) setargv$(o) .ENDIF $(GLOBBAT) : ..\lib\File\DosGlob.pm $(MINIPERL) $(MINIPERL) $(PL2BAT) - < ..\lib\File\DosGlob.pm > $(GLOBBAT) -perlglob.obj : perlglob.c +perlglob$(o) : perlglob.c -..\miniperlmain.obj : ..\miniperlmain.c $(CORE_H) +..\miniperlmain$(o) : ..\miniperlmain.c $(CORE_H) config.w32 : $(CFGSH_TMPL) copy $(CFGSH_TMPL) config.w32 @@ -413,16 +469,23 @@ $(CONFIGPM) : $(MINIPERL) ..\config.sh config_h.PL ..\minimod.pl $(XCOPY) *.h ..\lib\CORE\*.* $(RCOPY) include ..\lib\CORE\*.* $(MINIPERL) -I..\lib config_h.PL || $(MAKE) CCTYPE=$(CCTYPE) \ - RUNTIME=$(RUNTIME) CFG=$(CFG) $(CONFIGPM) + CFG=$(CFG) $(CONFIGPM) -$(MINIPERL) : ..\miniperlmain.obj $(CORE_OBJ) $(WIN32_OBJ) +LKPRE = INPUT ( +LKPOST = ) + +$(MINIPERL) : ..\miniperlmain$(o) $(CORE_OBJ) $(WIN32_OBJ) .IF "$(CCTYPE)" == "BORLAND" $(LINK32) -Tpe -ap $(LINK_FLAGS) \ - @$(mktmp c0x32.obj ..\miniperlmain.obj \ + @$(mktmp c0x32$(o) ..\miniperlmain$(o) \ $(CORE_OBJ:s,\,\\) $(WIN32_OBJ:s,\,\\),$@,,$(LIBFILES),) +.ELIF "$(CCTYPE)" == "GCC" + $(LINK32) -v -o $@ $(LINK_FLAGS) \ + $(mktmp $(LKPRE) ..\miniperlmain$(o) \ + $(CORE_OBJ:s,\,\\) $(WIN32_OBJ:s,\,\\) $(LIBFILES) $(LKPOST)) .ELSE $(LINK32) -subsystem:console -out:$@ \ - @$(mktmp $(LINK_FLAGS) $(LIBFILES) ..\miniperlmain.obj \ + @$(mktmp $(LINK_FLAGS) $(LIBFILES) ..\miniperlmain$(o) \ $(CORE_OBJ:s,\,\\) $(WIN32_OBJ:s,\,\\)) .ENDIF @@ -437,12 +500,24 @@ perldll.def : $(MINIPERL) $(CONFIGPM) ..\global.sym makedef.pl $(PERLDLL): perldll.def $(CORE_OBJ) $(WIN32_OBJ) $(DLL_OBJ) .IF "$(CCTYPE)" == "BORLAND" $(LINK32) -Tpd -ap $(LINK_FLAGS) \ - @$(mktmp c0d32.obj $(CORE_OBJ:s,\,\\) \ + @$(mktmp c0d32$(o) $(CORE_OBJ:s,\,\\) \ $(WIN32_OBJ:s,\,\\) $(DLL_OBJ:s,\,\\)\n \ $@,\n \ $(LIBFILES)\n \ perldll.def\n) $(IMPLIB) $*.lib $@ +.ELIF "$(CCTYPE)" == "GCC" + $(LINK32) -dll -o $@ -Wl,--base-file -Wl,perl.base $(LINK_FLAGS) \ + $(mktmp $(LKPRE) $(CORE_OBJ:s,\,\\) $(WIN32_OBJ:s,\,\\) \ + $(DLL_OBJ:s,\,\\) $(LIBFILES) $(LKPOST)) + dlltool --output-lib $(PERLIMPLIB) \ + --dllname perl.dll \ + --def perldll.def \ + --base-file perl.base \ + --output-exp perl.exp + $(LINK32) -dll -o $@ $(LINK_FLAGS) \ + $(mktmp $(LKPRE) $(CORE_OBJ:s,\,\\) $(WIN32_OBJ:s,\,\\) \ + $(DLL_OBJ:s,\,\\) $(LIBFILES) perl.exp $(LKPOST)) .ELSE $(LINK32) -dll -def:perldll.def -out:$@ \ @$(mktmp $(LINK_FLAGS) $(LIBFILES) $(CORE_OBJ:s,\,\\) \ @@ -459,45 +534,46 @@ $(MINIMOD) : $(MINIPERL) ..\minimod.pl perlmain.c : runperl.c copy runperl.c perlmain.c -perlmain.obj : perlmain.c - $(CC) $(CFLAGS) -UPERLDLL -c perlmain.c +perlmain$(o) : perlmain.c + $(CC) $(CFLAGS) -UPERLDLL $(EXEOUT_FLAG)$@ -c perlmain.c -$(PERLEXE): $(PERLDLL) $(CONFIGPM) perlmain.obj +$(PERLEXE): $(PERLDLL) $(CONFIGPM) perlmain$(o) .IF "$(CCTYPE)" == "BORLAND" $(LINK32) -Tpe -ap $(LINK_FLAGS) \ - @$(mktmp c0x32.obj perlmain.obj $(WINIOMAYBE)\n \ + @$(mktmp c0x32$(o) perlmain$(o) $(WINIOMAYBE)\n \ $@,\n \ $(PERLIMPLIB) $(LIBFILES)\n) +.ELIF "$(CCTYPE)" == "GCC" + $(LINK32) -o $@ $(LINK_FLAGS) \ + perlmain.o $(WINIOMAYBE) $(PERLIMPLIB) $(LIBFILES) .ELSE - $(LINK32) -subsystem:console -out:perl.exe $(LINK_FLAGS) $(LIBFILES) \ - perlmain.obj $(WINIOMAYBE) $(PERLIMPLIB) - copy perl.exe $@ - del perl.exe + $(LINK32) -subsystem:console -out:$@ $(LINK_FLAGS) $(LIBFILES) \ + perlmain$(o) $(WINIOMAYBE) $(PERLIMPLIB) .ENDIF copy splittree.pl .. $(MINIPERL) -I..\lib ..\splittree.pl "../LIB" "../LIB/auto" .IF "$(CCTYPE)" != "BORLAND" +.IF "$(CCTYPE)" != "GCC" perl95.c : runperl.c copy runperl.c perl95.c -perl95.obj : perl95.c +perl95$(o) : perl95.c $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c perl95.c -win32sckmt.obj : win32sck.c - $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32sckmt.obj win32sck.c +win32sckmt$(o) : win32sck.c + $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32sckmt$(o) win32sck.c -win32mt.obj : win32.c - $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32mt.obj win32.c +win32mt$(o) : win32.c + $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32mt$(o) win32.c $(PERL95EXE): $(PERLDLL) $(CONFIGPM) $(PERL95_OBJ) - $(LINK32) -subsystem:console -out:perl95.exe $(LINK_FLAGS) $(LIBFILES) \ + $(LINK32) -subsystem:console -out:$@ $(LINK_FLAGS) $(LIBFILES) \ $(PERL95_OBJ) $(PERLIMPLIB) - copy perl95.exe $@ - del perl95.exe .ENDIF +.ENDIF $(DYNALOADER).c: $(MINIPERL) $(EXTDIR)\DynaLoader\dl_win32.xs $(CONFIGPM) if not exist ..\lib\auto mkdir ..\lib\auto @@ -575,7 +651,7 @@ distclean: clean -del /f perl95.c .ENDIF -del /f bin\*.bat - -cd $(EXTDIR) && del /s *.lib *.def *.map *.bs Makefile *.obj pm_to_blib + -cd $(EXTDIR) && del /s *.lib *.def *.map *.bs Makefile *$(o) pm_to_blib -rmdir /s /q ..\lib\auto -rmdir /s /q ..\lib\CORE @@ -628,10 +704,10 @@ test-notty : test-prep cd ..\t && $(PERLEXE) -I.\lib harness clean : - -@erase miniperlmain.obj + -@erase miniperlmain$(o) -@erase $(MINIPERL) - -@erase perlglob.obj - -@erase perlmain.obj + -@erase perlglob$(o) + -@erase perlmain$(o) -@erase config.w32 -@erase /f config.h -@erase $(GLOBEXE) @@ -640,7 +716,7 @@ clean : -@erase $(CORE_OBJ) -@erase $(WIN32_OBJ) -@erase $(DLL_OBJ) - -@erase ..\*.obj ..\*.lib ..\*.exp *.obj *.lib *.exp + -@erase ..\*$(o) ..\*.lib ..\*.exp *$(o) *.lib *.exp -@erase ..\t\*.exe ..\t\*.dll ..\t\*.bat -@erase *.ilk -@erase *.pdb diff --git a/win32/makegcc.mk b/win32/makegcc.mk deleted file mode 100644 index 2396de9a8a..0000000000 --- a/win32/makegcc.mk +++ /dev/null @@ -1,531 +0,0 @@ -# -# Makefile to build perl on Windowns NT using Microsoft NMAKE. -# -# -# This is set up to build a perl.exe that runs off a shared library -# (perl.dll). Also makes individual DLLs for the XS extensions. -# - -# -# Set these to wherever you want "nmake install" to put your -# newly built perl. -INST_DRV=c: -INST_TOP=$(INST_DRV)\perl5004.5x -BUILDOPT=-DUSE_THREADS - - -# -# uncomment one if you are using Visual C++ 2.x or Borland -# comment out both if you are using Visual C++ 4.x and above -#CCTYPE=MSVC20 -CCTYPE=GCC - -# -# uncomment next line if you want debug version of perl (big,slow) -#CFG=Debug - -# -# set the install locations of the compiler include/libraries -#CCHOME = f:\msdev\vc -CCHOME = C:\Mingw32 -CCINCDIR = $(CCHOME)\include -CCLIBDIR = $(CCHOME)\lib - -# -# set this to point to cmd.exe (only needed if you use some -# alternate shell that doesn't grok cmd.exe style commands) -#SHELL = g:\winnt\system32\cmd.exe - -# -# set this to your email address (perl will guess a value from -# from your loginname and your hostname, which may not be right) -#EMAIL = - -##################### CHANGE THESE ONLY IF YOU MUST ##################### - -# -# Programs to compile, build .lib files and link -# - -.USESHELL : - -CC = gcc -pipe -LINK32 = gcc -LIB32 = ar -IMPLIB = dlltool - -# -# Options -# -RUNTIME = -D_RTLDLL -INCLUDES = -I.\include -I. -I.. -DEFINES = -DWIN32 $(BUILDOPT) -LOCDEFS = -DPERLDLL -DPERL_CORE -SUBSYS = console -LIBC = -lcrtdll -LIBFILES = -ladvapi32 -luser32 -lwsock32 -lmingw32 -lgcc -lmoldname $(LIBC) -lkernel32 - -WINIOMAYBE = - -.IF "$(CFG)" == "Debug" -OPTIMIZE = -g -O2 $(RUNTIME) -LINK_DBG = -g -.ELSE -OPTIMIZE = -g -O2 $(RUNTIME) -LINK_DBG = -.ENDIF - -CFLAGS = $(INCLUDES) $(DEFINES) $(LOCDEFS) $(OPTIMIZE) -LINK_FLAGS = -v $(LINK_DBG) -L$(CCLIBDIR) -OBJOUT_FLAG = -o - -#################### do not edit below this line ####################### -############# NO USER-SERVICEABLE PARTS BEYOND THIS POINT ############## - -# -# Rules -# -.SUFFIXES : -.SUFFIXES : .c .o .dll .lib .exe - -.c.o: - $(CC) -c $(CFLAGS) $(OBJOUT_FLAG) $@ $< - -.c.i: - $(CC) -E $(CFLAGS) $(OBJOUT_FLAG) $@ $< - -.o.dll: - $(LINK32) -o $@ $(LINK_FLAGS) $< $(LIBFILES), - $(IMPLIB) -def $(*B).def $(*B).lib $@ - -# -INST_BIN=$(INST_TOP)\bin -INST_LIB=$(INST_TOP)\lib -INST_POD=$(INST_LIB)\pod -INST_HTML=$(INST_POD)\html -LIBDIR=..\lib -EXTDIR=..\ext -PODDIR=..\pod -EXTUTILSDIR=$(LIBDIR)\extutils - -# -# various targets -PERLIMPLIB=..\perl.lib -MINIPERL=..\miniperl.exe -PERLDLL=..\perl.dll -PERLEXE=..\perl.exe -GLOBEXE=..\perlglob.exe -CONFIGPM=..\lib\Config.pm -MINIMOD=..\lib\ExtUtils\Miniperl.pm - -PL2BAT=bin\pl2bat.pl -GLOBBAT = bin\perlglob.bat - - -# Borland wildargs is incompatible with MS setargv -CFGSH_TMPL = config.gc -CFGH_TMPL = config_H.gc -# Borland's perl.exe will work on W95, so we don't make this - -XCOPY=xcopy /f /r /i /d -RCOPY=xcopy /f /r /i /e /d -#NULL= - -# -# filenames given to xsubpp must have forward slashes (since it puts -# full pathnames in #line strings) -XSUBPP=..\$(MINIPERL) -I..\..\lib ..\$(EXTUTILSDIR)\xsubpp -C++ -prototypes - -CORE_C= ..\av.c \ - ..\deb.c \ - ..\doio.c \ - ..\doop.c \ - ..\dump.c \ - ..\globals.c \ - ..\gv.c \ - ..\hv.c \ - ..\mg.c \ - ..\op.c \ - ..\perl.c \ - ..\perlio.c \ - ..\perly.c \ - ..\pp.c \ - ..\pp_ctl.c \ - ..\pp_hot.c \ - ..\pp_sys.c \ - ..\regcomp.c \ - ..\regexec.c \ - ..\run.c \ - ..\scope.c \ - ..\sv.c \ - ..\taint.c \ - ..\toke.c \ - ..\universal.c \ - ..\util.c \ - ..\malloc.c - -CORE_OBJ= ..\av.o \ - ..\deb.o \ - ..\doio.o \ - ..\doop.o \ - ..\dump.o \ - ..\globals.o \ - ..\gv.o \ - ..\hv.o \ - ..\mg.o \ - ..\op.o \ - ..\perl.o \ - ..\perlio.o \ - ..\perly.o \ - ..\pp.o \ - ..\pp_ctl.o \ - ..\pp_hot.o \ - ..\pp_sys.o \ - ..\regcomp.o \ - ..\regexec.o \ - ..\run.o \ - ..\scope.o \ - ..\sv.o \ - ..\taint.o \ - ..\toke.o \ - ..\universal.o\ - ..\util.o \ - ..\malloc.o - -WIN32_C = perllib.c \ - win32.c \ - win32sck.c \ - win32thread.c - -WIN32_OBJ = win32.o \ - win32sck.o \ - win32thread.o - -PERL95_OBJ = perl95.o \ - win32mt.o \ - win32sckmt.o - -DLL_OBJ = perllib.o $(DYNALOADER).o - -CORE_H = ..\av.h \ - ..\cop.h \ - ..\cv.h \ - ..\dosish.h \ - ..\embed.h \ - ..\form.h \ - ..\gv.h \ - ..\handy.h \ - ..\hv.h \ - ..\mg.h \ - ..\nostdio.h \ - ..\op.h \ - ..\opcode.h \ - ..\perl.h \ - ..\perlio.h \ - ..\perlsdio.h \ - ..\perlsfio.h \ - ..\perly.h \ - ..\pp.h \ - ..\proto.h \ - ..\regexp.h \ - ..\scope.h \ - ..\sv.h \ - ..\thread.h \ - ..\unixish.h \ - ..\util.h \ - ..\XSUB.h \ - .\config.h \ - ..\EXTERN.h \ - .\include\dirent.h \ - .\include\netdb.h \ - .\include\sys\socket.h \ - .\win32.h - -DYNAMIC_EXT=Socket IO Fcntl Opcode SDBM_File attrs Thread -STATIC_EXT=DynaLoader - -DYNALOADER=$(EXTDIR)\DynaLoader\DynaLoader -SOCKET=$(EXTDIR)\Socket\Socket -FCNTL=$(EXTDIR)\Fcntl\Fcntl -OPCODE=$(EXTDIR)\Opcode\Opcode -SDBM_FILE=$(EXTDIR)\SDBM_File\SDBM_File -IO=$(EXTDIR)\IO\IO -ATTRS=$(EXTDIR)\attrs\attrs -THREAD=$(EXTDIR)\Thread\Thread - -SOCKET_DLL=..\lib\auto\Socket\Socket.dll -FCNTL_DLL=..\lib\auto\Fcntl\Fcntl.dll -OPCODE_DLL=..\lib\auto\Opcode\Opcode.dll -SDBM_FILE_DLL=..\lib\auto\SDBM_File\SDBM_File.dll -IO_DLL=..\lib\auto\IO\IO.dll -ATTRS_DLL=..\lib\auto\attrs\attrs.dll -THREAD_DLL=..\lib\auto\Thread\Thread.dll - -STATICLINKMODULES=DynaLoader -DYNALOADMODULES= \ - $(SOCKET_DLL) \ - $(FCNTL_DLL) \ - $(OPCODE_DLL) \ - $(SDBM_FILE_DLL)\ - $(IO_DLL) \ - $(ATTRS_DLL) \ - $(THREAD_DLL) - -POD2HTML=$(PODDIR)\pod2html -POD2MAN=$(PODDIR)\pod2man -POD2LATEX=$(PODDIR)\pod2latex -POD2TEXT=$(PODDIR)\pod2text - -# -# Top targets -# -MAKE = dmake - -all: $(PERLEXE) $(PERL95EXE) $(GLOBEXE) $(DYNALOADMODULES) $(MINIMOD) $(GLOBBAT) - -$(DYNALOADER).o : $(DYNALOADER).c $(CORE_H) $(EXTDIR)\DynaLoader\dlutils.c - -#------------------------------------------------------------ - -$(GLOBEXE): perlglob.o - $(LINK32) $(LINK_FLAGS) -o $@ \ - perlglob.o $(LIBFILES) - -$(GLOBBAT) : ..\lib\File\DosGlob.pm $(MINIPERL) - $(MINIPERL) $(PL2BAT) - < ..\lib\File\DosGlob.pm > $(GLOBBAT) - -perlglob.o : perlglob.c - -..\miniperlmain.o : ..\miniperlmain.c $(CORE_H) - -config.w32 : $(CFGSH_TMPL) - copy $(CFGSH_TMPL) config.w32 - -.\config.h : $(CFGH_TMPL) - -del /f config.h - copy $(CFGH_TMPL) config.h - -..\config.sh : config.w32 $(MINIPERL) config_sh.PL - $(MINIPERL) -I..\lib config_sh.PL "INST_DRV=$(INST_DRV)" \ - "INST_TOP=$(INST_TOP)" "cc=$(CC)" "ccflags=$(OPTIMIZE) $(DEFINES)" \ - "cf_email=$(EMAIL)" "libs=$(LIBFILES:f)" "incpath=$(CCINCDIR)" \ - "libpth=$(strip $(CCLIBDIR) $(LIBFILES:d))" "libc=$(LIBC)" \ - "static_ext=$(STATIC_EXT)" "dynamic_ext=$(DYNAMIC_EXT)" \ - "ldflags=$(LINK_FLAGS)" "optimize=$(OPTIMIZE)" \ - config.w32 > ..\config.sh - -$(CONFIGPM) : $(MINIPERL) ..\config.sh config_h.PL ..\minimod.pl - cd .. && miniperl configpm - if exist lib\* $(RCOPY) lib\*.* ..\lib\$(NULL) - $(XCOPY) ..\*.h ..\lib\CORE\*.* - $(XCOPY) *.h ..\lib\CORE\*.* - $(RCOPY) include ..\lib\CORE\*.* - $(MINIPERL) -I..\lib config_h.PL || $(MAKE) -f makegcc.mk \ - CCTYPE=$(CCTYPE) RUNTIME=$(RUNTIME) CFG=$(CFG) $(CONFIGPM) - -LKPRE = INPUT ( -LKPOST = ) - -linkscript : ..\miniperlmain.o $(CORE_OBJ) $(WIN32_OBJ) - type $(mktmp $(LKPRE) ..\miniperlmain.o \ - $(CORE_OBJ:s,\,\\) $(WIN32_OBJ:s,\,\\) $(LIBFILES) $(LKPOST)) - - - -$(MINIPERL) : ..\miniperlmain.o $(CORE_OBJ) $(WIN32_OBJ) - $(LINK32) -v -o $@ $(LINK_FLAGS) \ - $(mktmp $(LKPRE) ..\miniperlmain.o \ - $(CORE_OBJ:s,\,\\) $(WIN32_OBJ:s,\,\\) $(LIBFILES) $(LKPOST)) - -$(WIN32_OBJ) : $(CORE_H) -$(CORE_OBJ) : $(CORE_H) -$(DLL_OBJ) : $(CORE_H) - -perldll.def : $(MINIPERL) $(CONFIGPM) ..\global.sym makedef.pl - $(MINIPERL) -w makedef.pl $(DEFINES) $(CCTYPE) > perldll.def - -$(PERLDLL): perldll.def $(CORE_OBJ) $(WIN32_OBJ) $(DLL_OBJ) - $(LINK32) -dll -o $@ -Wl,--base-file -Wl,perl.base $(LINK_FLAGS) \ - $(mktmp $(LKPRE) $(CORE_OBJ:s,\,\\) \ - $(WIN32_OBJ:s,\,\\) $(DLL_OBJ:s,\,\\) $(LIBFILES) $(LKPOST)) - dlltool --output-lib $(PERLIMPLIB) \ - --dllname perl.dll \ - --def perldll.def \ - --base-file perl.base \ - --output-exp perl.exp - $(LINK32) -dll -o $@ $(LINK_FLAGS) \ - $(mktmp $(LKPRE) $(CORE_OBJ:s,\,\\) \ - $(WIN32_OBJ:s,\,\\) $(DLL_OBJ:s,\,\\) $(LIBFILES) perl.exp $(LKPOST)) - $(XCOPY) $(PERLIMPLIB) ..\lib\CORE - -perl.def : $(MINIPERL) makeperldef.pl - $(MINIPERL) -I..\lib makeperldef.pl $(NULL) > perl.def - -$(MINIMOD) : $(MINIPERL) ..\minimod.pl - cd .. && miniperl minimod.pl > lib\ExtUtils\Miniperl.pm - -perlmain.c : runperl.c - copy runperl.c perlmain.c - -perlmain.o : perlmain.c - $(CC) $(CFLAGS) -UPERLDLL -o $@ -c perlmain.c - - -$(PERLEXE): $(PERLDLL) $(CONFIGPM) perlmain.o - $(LINK32) -o perl.exe $(LINK_FLAGS) \ - perlmain.o $(WINIOMAYBE) $(PERLIMPLIB) $(LIBFILES) - copy perl.exe $@ - del perl.exe - copy splittree.pl .. - $(MINIPERL) -I..\lib ..\splittree.pl "../LIB" "../LIB/auto" - - -$(DYNALOADER).c: $(MINIPERL) $(EXTDIR)\DynaLoader\dl_win32.xs $(CONFIGPM) - if not exist ..\lib\auto mkdir ..\lib\auto - $(XCOPY) $(EXTDIR)\$(*B)\$(*B).pm $(LIBDIR)\$(NULL) - cd $(EXTDIR)\$(*B) && $(XSUBPP) dl_win32.xs > $(*B).c - $(XCOPY) $(EXTDIR)\$(*B)\dlutils.c . - -$(EXTDIR)\DynaLoader\dl_win32.xs: dl_win32.xs - copy dl_win32.xs $(EXTDIR)\DynaLoader\dl_win32.xs - -$(THREAD_DLL): $(PERLEXE) $(THREAD).xs - cd $(EXTDIR)\$(*B) && \ - ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl - cd $(EXTDIR)\$(*B) && $(MAKE) - -$(ATTRS_DLL): $(PERLEXE) $(ATTRS).xs - cd $(EXTDIR)\$(*B) && \ - ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl - cd $(EXTDIR)\$(*B) && $(MAKE) - -$(IO_DLL): $(PERLEXE) $(IO).xs - cd $(EXTDIR)\$(*B) && \ - ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl - cd $(EXTDIR)\$(*B) && $(MAKE) - -$(SDBM_FILE_DLL) : $(PERLEXE) $(SDBM_FILE).xs - cd $(EXTDIR)\$(*B) && \ - ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl - cd $(EXTDIR)\$(*B) && $(MAKE) - -$(FCNTL_DLL): $(PERLEXE) $(FCNTL).xs - cd $(EXTDIR)\$(*B) && \ - ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl - cd $(EXTDIR)\$(*B) && $(MAKE) - -$(OPCODE_DLL): $(PERLEXE) $(OPCODE).xs - cd $(EXTDIR)\$(*B) && \ - ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl - cd $(EXTDIR)\$(*B) && $(MAKE) - -$(SOCKET_DLL): $(PERLEXE) $(SOCKET).xs - cd $(EXTDIR)\$(*B) && \ - ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl - cd $(EXTDIR)\$(*B) && $(MAKE) - -doc: $(PERLEXE) - cd ..\pod && $(MAKE) -f ..\win32\pod.mak checkpods \ - pod2html pod2latex pod2man pod2text - cd ..\pod && $(XCOPY) *.bat ..\win32\bin\*.* - copy ..\README.win32 ..\pod\perlwin32.pod - $(PERLEXE) ..\installhtml --podroot=.. --htmldir=./html \ - --podpath=pod:lib:ext:utils --htmlroot="//$(INST_HTML:s,:,|,)" \ - --libpod=perlfunc:perlguts:perlvar:perlrun:perlop --recurse - -utils: $(PERLEXE) - cd ..\utils && $(MAKE) PERL=$(MINIPERL) - cd ..\utils && $(PERLEXE) ..\win32\$(PL2BAT) h2ph splain perlbug \ - pl2pm c2ph h2xs perldoc pstruct - $(XCOPY) ..\utils\*.bat bin\*.* - $(PERLEXE) $(PL2BAT) bin\network.pl bin\www.pl bin\runperl.pl \ - bin\pl2bat.pl - -distclean: clean - -del /f $(MINIPERL) $(PERLEXE) $(PERL95EXE) $(PERLDLL) $(GLOBEXE) \ - $(PERLIMPLIB) ..\miniperl.lib $(MINIMOD) - -del /f *.def *.map - -del /f $(SOCKET_DLL) $(IO_DLL) $(SDBM_FILE_DLL) $(FCNTL_DLL) \ - $(OPCODE_DLL) $(ATTRS_DLL) $(THREAD_DLL) - -del /f $(SOCKET).c $(IO).c $(SDBM_FILE).c $(FCNTL).c $(OPCODE).c \ - $(DYNALOADER).c $(ATTRS).c $(THREAD).c - -del /f $(PODDIR)\*.html - -del /f $(PODDIR)\*.bat - -del /f ..\config.sh ..\splittree.pl perlmain.c dlutils.c config.h.new -.IF "$(PERL95EXE)" != "" - -del /f perl95.c -.ENDIF - -del /f bin\*.bat - -cd $(EXTDIR) && del /s *.lib *.def *.map *.bs Makefile *.o pm_to_blib - -rmdir /s /q ..\lib\auto - -rmdir /s /q ..\lib\CORE - -install : all doc utils - if not exist $(INST_TOP) mkdir $(INST_TOP) - echo I $(INST_TOP) L $(LIBDIR) - $(XCOPY) $(PERLEXE) $(INST_BIN)\*.* -.IF "$(PERL95EXE)" != "" - $(XCOPY) $(PERL95EXE) $(INST_BIN)\*.* -.ENDIF - $(XCOPY) $(GLOBEXE) $(INST_BIN)\*.* - $(XCOPY) $(PERLDLL) $(INST_BIN)\*.* - $(XCOPY) bin\*.bat $(INST_BIN)\*.* - $(RCOPY) ..\lib $(INST_LIB)\*.* - $(XCOPY) ..\pod\*.bat $(INST_BIN)\*.* - $(XCOPY) ..\pod\*.pod $(INST_POD)\*.* - $(RCOPY) html\*.* $(INST_HTML)\*.* - -inst_lib : $(CONFIGPM) - copy splittree.pl .. - $(MINIPERL) -I..\lib ..\splittree.pl "../LIB" "../LIB/auto" - $(RCOPY) ..\lib $(INST_LIB)\*.* - -minitest : $(MINIPERL) $(GLOBEXE) $(CONFIGPM) - $(XCOPY) $(MINIPERL) ..\t\perl.exe -.IF "$(CCTYPE)" == "BORLAND" - $(XCOPY) $(GLOBBAT) ..\t\$(NULL) -.ELSE - $(XCOPY) $(GLOBEXE) ..\t\$(NULL) -.ENDIF - attrib -r ..\t\*.* - copy test ..\t - cd ..\t && \ - $(MINIPERL) -I..\lib test base/*.t comp/*.t cmd/*.t io/*.t op/*.t pragma/*.t - -test-prep : all - $(XCOPY) $(PERLEXE) ..\t\$(NULL) - $(XCOPY) $(PERLDLL) ..\t\$(NULL) -.IF "$(CCTYPE)" == "BORLAND" - $(XCOPY) $(GLOBBAT) ..\t\$(NULL) -.ELSE - $(XCOPY) $(GLOBEXE) ..\t\$(NULL) -.ENDIF - -test : test-prep - cd ..\t && $(PERLEXE) -I..\lib harness - -test-notty : test-prep - set PERL_SKIP_TTY_TEST=1 && \ - cd ..\t && $(PERLEXE) -I.\lib harness - -clean : - -@erase miniperlmain.o - -@erase $(MINIPERL) - -@erase perlglob.o - -@erase perlmain.o - -@erase config.w32 - -@erase /f config.h - -@erase $(GLOBEXE) - -@erase $(PERLEXE) - -@erase $(PERLDLL) - -@erase $(CORE_OBJ) - -@erase $(WIN32_OBJ) - -@erase $(DLL_OBJ) - -@erase ..\*.o ..\*.lib ..\*.exp *.o *.lib *.exp - -@erase ..\t\*.exe ..\t\*.dll ..\t\*.bat - -@erase *.ilk - -@erase *.pdb - - - - diff --git a/win32/win32.h b/win32/win32.h index c1e0121932..a58e884fc8 100644 --- a/win32/win32.h +++ b/win32/win32.h @@ -18,6 +18,9 @@ typedef long long __int64; #define __declspec(x) #define PERL_GLOBAL_STRUCT #define MULTIPLICITY +#ifndef TLS_OUT_OF_INDEXES +#define TLS_OUT_OF_INDEXES (DWORD)0xFFFFFFFF +#endif #endif /* Define DllExport akin to perl's EXT, |