Sarathy's patch
[p5sagit/p5-mst-13.2.git] / win32 / Makefile
index 1136d15..2411ff4 100644 (file)
 # 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.
 #
-# There's no support for building an all-static perl yet.
-# Doesn't build any of the stuff in ..\utils yet.
-# No support for installing documentation, uh, yet.
+
+#
+# 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 
+CORECCOPT=
+
+#
+# uncomment next line if you are using Visual C++ 2.x
+#CCTYPE=MSVC20
+
 #
+# 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:\msvc20
+CCHOME = $(MSVCDIR)
+CCINCDIR = $(CCHOME)\include
+CCLIBDIR = $(CCHOME)\lib
+
+#
+# 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
+#
+
+CC=cl.exe
+LINK32=link.exe
+LIB32=$(LINK32) -lib
+#
+# Options
+#
+!IF "$(RUNTIME)" == ""
+RUNTIME  = -MD
+!ENDIF
+INCLUDES = -I.\include -I. -I..
+#PCHFLAGS = -Fp"$(INTDIR)/modules.pch" -YX 
+DEFINES  = -DWIN32 -D_CONSOLE $(BUILDOPT)
+LOCDEFS  = -DPERLDLL $(CORECCOPT)
+SUBSYS   = console
+
+!IF "$(RUNTIME)" == "-MD"
+LIBC = msvcrt.lib
+WINIOMAYBE =
+!ELSE
+LIBC = libcmt.lib
+WINIOMAYBE =
+!ENDIF
+
+!IF  "$(CFG)" == "Debug"
+!  IF "$(CCTYPE)" == "MSVC20"
+OPTIMIZE = -Od $(RUNTIME) -Z7 -D_DEBUG
+!  ELSE
+OPTIMIZE = -Od $(RUNTIME)d -Z7 -D_DEBUG
+!  ENDIF
+LINK_DBG = -debug -pdb:none
+!ELSE
+!  IF "$(CCTYPE)" == "MSVC20"
+OPTIMIZE = -Od $(RUNTIME) -DNDEBUG
+!  ELSE
+OPTIMIZE = -Od $(RUNTIME) -DNDEBUG
+!  ENDIF
+LINK_DBG = -release
+!ENDIF
+
+# 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)
+LINK_FLAGS  = -nologo $(LINK_DBG) -machine:$(PROCESSOR_ARCHITECTURE)
+OBJOUT_FLAG = -Fo
 
+#################### do not edit below this line #######################
+############# NO USER-SERVICEABLE PARTS BEYOND THIS POINT ##############
 
 #
-# Set this to wherever you want "nmake install" to put your
-# newly built perl.  If you change this, you better change
-# all occurrences of this prefix in $(INST_TOP)\lib\Config.pm
-# as well.
+# Rules
+# 
+.SUFFIXES : 
+.SUFFIXES : .c .obj .dll .lib .exe
 
-INST_TOP=C:\perl
+.c.obj:
+       $(CC) -c $(CFLAGS) $(OBJOUT_FLAG)$@ $<
+
+.obj.dll:
+       $(LINK32) -dll -subsystem:windows -implib:$(*B).lib -def:$(*B).def \
+           -out:$@ $(LINK_FLAGS) $(LIBFILES) $< $(LIBPERL)  
 
-#################### do not edit below this line ########################
 #
 INST_BIN=$(INST_TOP)\bin
 INST_LIB=$(INST_TOP)\lib
-INST_POD=$(INST_TOP)\pod
+INST_POD=$(INST_LIB)\pod
 INST_HTML=$(INST_POD)\html
 LIBDIR=..\lib
 EXTDIR=..\ext
@@ -32,25 +120,31 @@ EXTUTILSDIR=$(LIBDIR)\extutils
 
 #
 # various targets
-PERLLIB=..\libperl.lib
 PERLIMPLIB=..\perl.lib
 MINIPERL=..\miniperl.exe
 PERLDLL=..\perl.dll
 PERLEXE=..\perl.exe
 GLOBEXE=..\perlglob.exe
-
-PL2BAT=bin\PL2BAT.BAT
-MAKE=nmake /nologo
-XCOPY=xcopy /i /d /f /r
+CONFIGPM=..\lib\Config.pm
+MINIMOD=..\lib\ExtUtils\Miniperl.pm
+
+PL2BAT=bin\pl2bat.pl
+GLOBBAT = bin\perlglob.bat
+
+MAKE=nmake -nologo
+CFGSH_TMPL = config.vc
+CFGH_TMPL = config_H.vc
+PERL95EXE=..\perl95.exe
+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) ..\$(EXTUTILSDIR)\xsubpp -C++ -prototypes
+XSUBPP=..\$(MINIPERL) -I..\..\lib ..\$(EXTUTILSDIR)\xsubpp -C++ -prototypes
 
-CORE_C=                        \
-       ..\av.c         \
+CORE_C=        ..\av.c         \
        ..\deb.c        \
        ..\doio.c       \
        ..\doop.c       \
@@ -75,9 +169,91 @@ CORE_C=                     \
        ..\taint.c      \
        ..\toke.c       \
        ..\universal.c  \
-       ..\util.c
-
-EXTENSIONS=DynaLoader Socket IO Fcntl Opcode SDBM_File
+       ..\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      
+
+WIN32_C = perllib.c \
+       win32.c \
+       win32sck.c \
+       win32thread.c 
+
+WIN32_OBJ = win32.obj \
+       win32sck.obj \
+       win32thread.obj 
+
+PERL95_OBJ = perl95.obj \
+       win32mt.obj \
+       win32sckmt.obj
+
+DLL_OBJ = perllib.obj $(DYNALOADER).obj
+
+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     \
+       ..\perlvars.h   \
+       ..\intrpvar.h   \
+       ..\thrdvar.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
@@ -85,12 +261,16 @@ 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=       \
@@ -98,62 +278,121 @@ DYNALOADMODULES=  \
        $(FCNTL_DLL)    \
        $(OPCODE_DLL)   \
        $(SDBM_FILE_DLL)\
-       $(IO_DLL)
+       $(IO_DLL)       \
+       $(ATTRS_DLL)    \
+       $(THREAD_DLL)
 
 POD2HTML=$(PODDIR)\pod2html
 POD2MAN=$(PODDIR)\pod2man
 POD2LATEX=$(PODDIR)\pod2latex
 POD2TEXT=$(PODDIR)\pod2text
 
-ALL: $(PERLEXE) $(GLOBEXE) $(DYNALOADMODULES)
+#
+# Top targets
+#
 
-!IF "$(CFG)" ==""
-CFG=Release
-!ENDIF
+all: $(PERLEXE) $(PERL95EXE) $(GLOBEXE) $(DYNALOADMODULES) $(MINIMOD) $(GLOBBAT)
 
-modules.lib : $(DYNALOADER).c
-       $(MAKE) -A -f modules.mak CFG="modules - Win32 $(CFG)"
+$(DYNALOADER).obj : $(DYNALOADER).c $(CORE_H) $(EXTDIR)\DynaLoader\dlutils.c
 
-$(GLOBEXE):
-       $(MAKE) -f perlglob.mak CFG="perlglob - Win32 Release"
+#------------------------------------------------------------
 
-$(PERLLIB): $(CORE_C)
-       $(MAKE) -f libperl.mak CFG="libperl - Win32 $(CFG)"
+$(GLOBEXE): perlglob.obj
+       $(LINK32) $(LINK_FLAGS) $(LIBFILES) -out:$@ -subsystem:$(SUBSYS) \
+           perlglob.obj setargv.obj 
 
-$(MINIPERL): $(PERLLIB)
-       $(MAKE) -A -f miniperl.mak CFG="miniperl - Win32 $(CFG)"
-       copy config.w32 ..\config.sh
-       cd ..
-       miniperl configpm
-       cd win32
-       if exist lib\* $(XCOPY) /e lib\*.* ..\lib\$(NULL)
-       copy bin\test.bat ..\t
+$(GLOBBAT) : ..\lib\File\DosGlob.pm $(MINIPERL)
+       $(MINIPERL) $(PL2BAT) - < ..\lib\File\DosGlob.pm > $(GLOBBAT)
 
-$(PERLDLL): $(MINIPERL) $(PERLLIB)
-       $(MINIPERL) -w makedef.pl > perldll.def
-       $(MAKE) -A -f perldll.mak CFG="perldll - Win32 $(CFG)"
+perlglob.obj  : perlglob.c
 
-$(PERLEXE): $(MINIPERL) modules.lib $(PERLDLL)
-#      $(MINIPERL) makemain.pl $(STATICLINKMODUES) > perlmain.c
-#      $(MINIPERL) makeperldef.pl $(STATICLINKMODUES) > perl.def
-       $(MINIPERL) makeperldef.pl $(NULL) > perl.def
-       copy runperl.c perlmain.c
-       $(MAKE) -A -f perl.mak CFG="perl - Win32 $(CFG)"
-       copy ..\_perl.exe $(PERLEXE)
-       del ..\_perl.exe
-       del ..\*.exp
-       copy splittree.pl .. 
-       $(MINIPERL) ..\splittree.pl "../LIB" "../LIB/auto"
-       attrib -r ..\t\*.*
-       copy test ..\t
+..\miniperlmain.obj : ..\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)" "incpath=$(CCINCDIR)" \
+           "libpth=$(CCLIBDIR)" "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) CCTYPE=$(CCTYPE) \
+           RUNTIME=$(RUNTIME) CFG=$(CFG) $(CONFIGPM)
+
+$(MINIPERL) : ..\miniperlmain.obj $(CORE_OBJ) $(WIN32_OBJ)
+       $(LINK32) -subsystem:console -out:$@ @<<
+       $(LINK_FLAGS) $(LIBFILES) ..\miniperlmain.obj $(CORE_OBJ) $(WIN32_OBJ)
+<<
+
+$(WIN32_OBJ)  : $(CORE_H)
+$(CORE_OBJ)   : $(CORE_H)
+$(DLL_OBJ)    : $(CORE_H) 
+$(PERL95_OBJ) : $(CORE_H)
+
+perldll.def : $(MINIPERL) $(CONFIGPM) makedef.pl ..\global.sym
+       $(MINIPERL) -w makedef.pl $(DEFINES) $(CCTYPE) > perldll.def
+
+$(PERLDLL): perldll.def $(CORE_OBJ) $(WIN32_OBJ) $(DLL_OBJ)
+       $(LINK32) -dll -def:perldll.def -out:$@ @<<
+               $(LINK_FLAGS) $(LIBFILES) $(CORE_OBJ) $(WIN32_OBJ) $(DLL_OBJ)
+<<
        $(XCOPY) $(PERLIMPLIB) ..\lib\CORE
-       $(XCOPY) $(PERLLIB) ..\lib\CORE
-       $(XCOPY) *.h ..\lib\CORE
-       $(XCOPY) /S include ..\lib\CORE
 
-$(DYNALOADER).c: $(EXTDIR)\DynaLoader\dl_win32.xs
-       if not exist ..\lib\auto md ..\lib\auto
+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.obj : perlmain.c
+       $(CC) $(CFLAGS) -UPERLDLL -c perlmain.c
+
+$(PERLEXE): $(PERLDLL) $(CONFIGPM) perlmain.obj  
+       $(LINK32) -subsystem:console -out:perl.exe $(LINK_FLAGS) $(LIBFILES) \
+           perlmain.obj $(WINIOMAYBE) $(PERLIMPLIB) 
+       copy perl.exe $@
+       del perl.exe
+       copy splittree.pl .. 
+       $(MINIPERL) -I..\lib ..\splittree.pl "../LIB" "../LIB/auto"
+
+perl95.c : runperl.c 
+       copy runperl.c perl95.c
+
+perl95.obj : 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
+
+win32mt.obj : win32.c
+       $(CC) $(CFLAGS) -MT -UPERLDLL -DWIN95FIX -c $(OBJOUT_FLAG)win32mt.obj win32.c
+
+$(PERL95EXE): $(PERLDLL) $(CONFIGPM) $(PERL95_OBJ)
+       $(LINK32) -subsystem:console -out:perl95.exe $(LINK_FLAGS) $(LIBFILES) \
+           $(PERL95_OBJ) $(PERLIMPLIB) 
+       copy perl95.exe $@
+       del perl95.exe
+
+$(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
@@ -162,120 +401,148 @@ $(DYNALOADER).c: $(EXTDIR)\DynaLoader\dl_win32.xs
 $(EXTDIR)\DynaLoader\dl_win32.xs: dl_win32.xs
        copy dl_win32.xs $(EXTDIR)\DynaLoader\dl_win32.xs
 
-$(SOCKET).c: $(SOCKET).xs
-       if not exist ..\lib\auto\$(*B) md ..\lib\auto\$(*B)
-       $(MINIPERL) genxsdef.pl $(*B) > $(*B).def
-       $(XCOPY) $(EXTDIR)\$(*B)\$(*B).pm $(LIBDIR)\$(NULL)
+$(ATTRS_DLL): $(PERLEXE) $(ATTRS).xs
        cd $(EXTDIR)\$(*B)
-       $(XSUBPP) $(*B).xs > $(*B).c
+       ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl
+       $(MAKE)
        cd ..\..\win32
 
-$(IO).c:  $(IO).xs
-       if not exist ..\lib\auto\$(*B) md ..\lib\auto\$(*B)
-       $(MINIPERL) genxsdef.pl $(*B) > $(*B).def
-       $(XCOPY) $(EXTDIR)\$(*B)\$(*B).pm $(LIBDIR)\$(NULL)
-       $(XCOPY) /s $(EXTDIR)\$(*B)\lib\*.* $(LIBDIR)
+$(THREAD_DLL): $(PERLEXE) $(THREAD).xs
        cd $(EXTDIR)\$(*B)
-       $(XSUBPP) $(*B).xs > $(*B).c
+       ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl
+       $(MAKE)
        cd ..\..\win32
 
-$(SDBM_FILE).c:  $(SDBM_FILE).xs
-       if not exist ..\lib\auto\$(*B) md ..\lib\auto\$(*B)
-       $(MINIPERL) genxsdef.pl $(*B) > $(*B).def
-       $(XCOPY) $(EXTDIR)\$(*B)\$(*B).pm $(LIBDIR)\$(NULL)
+
+$(IO_DLL): $(PERLEXE) $(CONFIGPM) $(IO).xs
        cd $(EXTDIR)\$(*B)
-       $(XSUBPP) -typemap ./typemap $(*B).xs > $(*B).c
+       ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl
+       $(MAKE)
        cd ..\..\win32
 
-$(FCNTL).c:  $(FCNTL).xs
-       if not exist ..\lib\auto\$(*B) md ..\lib\auto\$(*B)
-       $(MINIPERL) genxsdef.pl $(*B) > $(*B).def
-       $(XCOPY) $(EXTDIR)\$(*B)\$(*B).pm $(LIBDIR)\$(NULL)
+$(SDBM_FILE_DLL) : $(PERLEXE) $(SDBM_FILE).xs
        cd $(EXTDIR)\$(*B)
-       $(XSUBPP) $(*B).xs > $(*B).c
+       ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl
+       $(MAKE)
        cd ..\..\win32
 
-$(OPCODE).c:  $(OPCODE).xs
-       if not exist ..\lib\auto\$(*B) md ..\lib\auto\$(*B)
-       $(MINIPERL) genxsdef.pl $(*B) > $(*B).def
-       $(XCOPY) $(EXTDIR)\$(*B)\$(*B).pm $(LIBDIR)\$(NULL)
-       $(XCOPY) $(EXTDIR)\$(*B)\*.pm $(LIBDIR)\$(NULL)
+$(FCNTL_DLL): $(PERLEXE) $(FCNTL).xs
        cd $(EXTDIR)\$(*B)
-       $(XSUBPP) $(*B).xs > $(*B).c
+       ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl
+       $(MAKE)
        cd ..\..\win32
 
-$(SOCKET_DLL): $(SOCKET).c $(PERLDLL)
-       $(MAKE) -f $(*B).mak CFG="$(*B) - Win32 $(CFG)"
-
-$(IO_DLL): $(IO).c $(PERLDLL)
-       $(MAKE) -f $(*B).mak CFG="$(*B) - Win32 $(CFG)"
-
-$(SDBM_FILE_DLL): $(SDBM_FILE).c $(PERLDLL)
-       $(MAKE) -f $(*B).mak CFG="$(*B) - Win32 $(CFG)"
-
-$(FCNTL_DLL): $(FCNTL).c $(PERLDLL)
-       $(MAKE) -f $(*B).mak CFG="$(*B) - Win32 $(CFG)"
+$(OPCODE_DLL): $(PERLEXE) $(OPCODE).xs
+       cd $(EXTDIR)\$(*B)
+       ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl
+       $(MAKE)
+       cd ..\..\win32
 
-$(OPCODE_DLL): $(OPCODE).c $(PERLDLL)
-       $(MAKE) -f $(*B).mak CFG="$(*B) - Win32 $(CFG)"
+$(SOCKET_DLL): $(PERLEXE) $(SOCKET).xs
+       cd $(EXTDIR)\$(*B)
+       ..\..\miniperl -I..\..\lib Makefile.PL INSTALLDIRS=perl
+       $(MAKE)
+       cd ..\..\win32
 
 doc: $(PERLEXE)
-       $(PERLEXE) $(POD2HTML).PL
-       $(PERLEXE) $(POD2MAN).PL
-       $(PERLEXE) $(POD2LATEX).PL
-       $(PERLEXE) $(POD2TEXT).PL
-       $(PERLEXE) $(PL2BAT) $(POD2HTML)
-       $(PERLEXE) $(PL2BAT) $(POD2MAN)
-       $(PERLEXE) $(PL2BAT) $(POD2LATEX)
-       $(PERLEXE) $(PL2BAT) $(POD2TEXT)
-        cd $(PODDIR)
-        $(PERLEXE) pod2html.bat *.pod
-        cd ..\win32
+       cd ..\pod
+       $(MAKE) -f ..\win32\pod.mak checkpods pod2html pod2latex \
+               pod2man pod2text
+       $(XCOPY) *.bat ..\win32\bin\*.*
+       cd ..\win32
+       copy ..\README.win32 ..\pod\perlwin32.pod
+       $(PERLEXE) ..\installhtml --podroot=.. --htmldir=./html \
+           --podpath=pod:lib:ext:utils --htmlroot="//$(INST_HTML::=|)" \
+           --libpod=perlfunc:perlguts:perlvar:perlrun:perlop --recurse
 
 utils: $(PERLEXE)
        cd ..\utils
        nmake PERL=$(MINIPERL)
-       $(PERLEXE) ..\win32\$(PL2BAT) h2ph splain perlbug pl2pm c2ph \
-                       h2xs perldoc pstruct
+       $(PERLEXE) ..\win32\$(PL2BAT) h2ph splain perlbug pl2pm c2ph
+       $(PERLEXE) ..\win32\$(PL2BAT) h2xs perldoc pstruct
        $(XCOPY) *.bat ..\win32\bin\*.*
        cd ..\win32
+       $(PERLEXE) $(PL2BAT) bin\network.pl bin\www.pl bin\runperl.pl \
+                       bin\pl2bat.pl
 
-distclean:
-       -del /f $(MINIPERL) $(PERLEXE) $(PERLDLL) $(GLOBEXE) $(PERLLIB) \
-               $(PERLIMPLIB) ..\miniperl.lib modules.lib
-       -del /f *.def
+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)
+               $(OPCODE_DLL) $(ATTRS_DLL) $(THREAD_DLL)
        -del /f $(SOCKET).c $(IO).c $(SDBM_FILE).c $(FCNTL).c $(OPCODE).c \
-               $(DYNALOADER).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 perl95.c
+       -del /f bin\*.bat
        -rmdir /s /q ..\lib\auto
        -rmdir /s /q ..\lib\CORE
-       -rmdir /s /q release
-       -rmdir /s /q debug
+       cd $(EXTDIR)
+       -del /s *.lib *.def *.map *.bs Makefile *.obj pm_to_blib
+       cd ..\win32
 
-install : ALL doc utils
+install : all doc utils
        if not exist $(INST_TOP) mkdir $(INST_TOP)
        echo I $(INST_TOP) L $(LIBDIR)
        $(XCOPY) $(PERLEXE) $(INST_BIN)\*.*
+       $(XCOPY) $(PERL95EXE) $(INST_BIN)\*.*
        $(XCOPY) $(GLOBEXE) $(INST_BIN)\*.*
        $(XCOPY) $(PERLDLL) $(INST_BIN)\*.*
-       $(XCOPY) bin\*.* $(INST_BIN)\*.*
-       $(XCOPY) /e ..\lib $(INST_LIB)\*.*
+       $(XCOPY) bin\*.bat $(INST_BIN)\*.*
+       $(RCOPY) ..\lib $(INST_LIB)\*.*
        $(XCOPY) ..\pod\*.bat $(INST_BIN)\*.*
        $(XCOPY) ..\pod\*.pod $(INST_POD)\*.*
-       $(XCOPY) ..\pod\*.html $(INST_HTML)\*.*
+       $(RCOPY) html\*.* $(INST_HTML)\*.*
 
-inst_lib : 
+inst_lib : $(CONFIGPM)
        copy splittree.pl .. 
-       $(MINIPERL) ..\splittree.pl "../LIB" "../LIB/auto"
-       $(XCOPY) /e ..\lib $(INST_LIB)\*.*
+       $(MINIPERL) -I..\lib ..\splittree.pl "../LIB" "../LIB/auto"
+       $(RCOPY) ..\lib $(INST_LIB)\*.*
+
+minitest : $(MINIPERL) $(GLOBEXE) $(CONFIGPM)
+       $(XCOPY) $(MINIPERL) ..\t\perl.exe
+       $(XCOPY) $(GLOBEXE) ..\t\$(NULL)
+       attrib -r ..\t\*.*
+       copy test ..\t
+       cd ..\t
+       $(MINIPERL) -I..\lib test base/*.t comp/*.t cmd/*.t io/*.t op/*.t pragma/*.t
+       cd ..\win32
 
-test : all
+test-prep : all
        $(XCOPY) $(PERLEXE) ..\t\$(NULL)
        $(XCOPY) $(PERLDLL) ..\t\$(NULL)
        $(XCOPY) $(GLOBEXE) ..\t\$(NULL)
-        cd ..\t
-        $(PERLEXE) test
+
+test : test-prep
+       cd ..\t
+       $(PERLEXE) -I..\lib harness
        cd ..\win32
+
+test-notty : test-prep
+       set PERL_SKIP_TTY_TEST=1
+       cd ..\t
+       $(PERLEXE) -I..\lib harness
+       cd ..\win32
+
+clean : 
+       -@erase miniperlmain.obj
+       -@erase $(MINIPERL)
+       -@erase perlglob.obj
+       -@erase perlmain.obj
+       -@erase config.w32
+       -@erase /f config.h
+       -@erase $(GLOBEXE)
+       -@erase $(PERLEXE)
+       -@erase $(PERLDLL)
+       -@erase $(CORE_OBJ)
+       -@erase $(WIN32_OBJ)
+       -@erase $(DLL_OBJ)
+       -@erase ..\*.obj ..\*.lib ..\*.exp *.obj *.lib *.exp
+       -@erase ..\t\*.exe ..\t\*.dll ..\t\*.bat
+       -@erase *.ilk
+       -@erase *.pdb
+
+