]> code.delx.au - gnu-emacs/blobdiff - nt/makefile.nt
(mouse-drag-throw): Bind adjusted-mouse-delta.
[gnu-emacs] / nt / makefile.nt
index 82372fa298936bbff2e16732c551125d4ca33add..9c34d0ea0f37734d25e4d840f3cd51d11c1f2463 100644 (file)
 #  
 #  You should have received a copy of the GNU General Public License
 #  along with GNU Emacs; see the file COPYING.  If not, write to
-#  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
+#  the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+#  Boston, MA 02111-1307, USA.
 #
 #   Geoff Voelker (voelker@cs.washington.edu)  11-20-93
 #                                                9-6-94
 !include makefile.def
 
-SUBDIRS              = lib-src src lisp
+ALL            = $(BLD)\addpm.exe $(BLD)\runemacs.exe
+!if $(MSVCNT11)
+TRES           = $(BLD)\emacs.res
+!else
+TRES           = $(BLD)\emacs.rbj
+!endif
+
+.c{$(BLD)}.obj:
+                 $(CC) $(CFLAGS) -Fo$@ $<
+
+addpm:           $(BLD) $(BLD)\addpm.exe
+$(BLD)\addpm.obj: addpm.c
+$(BLD)\addpm.exe: $(BLD)\addpm.obj
+                 $(LINK) -out:$@ -subsystem:console -entry:mainCRTStartup \
+                 $(SYS_LDFLAGS) $** $(BASE_LIBS) $(ADVAPI32) user32.lib
+
+#
+# The resource file.  NT 3.10 requires the use of cvtres; even though
+# it is not necessary on later versions, it is still ok to use it.
+#
+$(TRES):       emacs.rc
+               $(RC) -Fo$(BLD)\emacs.res $**
+!if !$(MSVCNT11)
+               $(CVTRES) -r -$(ARCH) -o $@ $(BLD)\emacs.res
+!endif
+
+runemacs:        $(BLD) $(BLD)\runemacs.exe
+$(BLD)\runemacs.obj: runemacs.c
+$(BLD)\runemacs.exe: $(BLD)\runemacs.obj $(TRES)
+                 $(LINK) -out:$@ -subsystem:windows -entry:WinMainCRTStartup \
+                 $(SYS_LDFLAGS) $** $(BASE_LIBS) $(ADVAPI32) user32.lib
+
+# Since Windows 95 does not support multiple commands on one command line
+# (e.g., in for loops), we cannot use for loops any more.
+# SUBDIRS            = lib-src src lisp
 
 #
 # Build emacs
 #
-all:;          for %%f in ( $(SUBDIRS) ) do cd ..\%%f & $(MAKE) -f makefile.nt all
+BUILD_CMD      = $(MAKE) -f makefile.nt all
+all:           $(BLD) $(ALL)
+               cd ..\lib-src
+               $(BUILD_CMD)
+               cd ..\src
+               $(BUILD_CMD)
+               cd ..\lisp
+               $(BUILD_CMD)
+               cd ..\nt
+
+
+emacs.bat:     emacs.bat.in
+               echo @echo off > emacs.bat
+               echo REM !!! Warning: This file automatically generated !!! >> emacs.bat
+               echo set emacs_dir=$(INSTALL_DIR)>> emacs.bat
+               type emacs.bat.in >> emacs.bat
 
 #
 # Build and install emacs in INSTALL_DIR
 #
-install:       all
+INSTALL_CMD    = $(MAKE) -f makefile.nt install
+install:       all emacs.bat
                - mkdir $(INSTALL_DIR)
-               for %%f in ( $(SUBDIRS) ) do cd ..\%%f & $(MAKE) -f makefile.nt install
+               cd ..\lib-src
+               $(INSTALL_CMD)
+               cd ..\src
+               $(INSTALL_CMD)
+               cd ..\lisp
+               $(INSTALL_CMD)
+               cd ..\nt                
                - $(CP) emacs.bat $(INSTALL_DIR)\bin
-               - del /q ..\same-dir.tst
-               - del /q $(INSTALL_DIR)\same-dir.tst
-               echo SameDirTest > ..\same-dir.tst
-               if not exist $(INSTALL_DIR)\same-dir.tst $(MAKE) -f makefile.nt real_install
-               - del /q ..\same-dir.tst
-               - del /q $(INSTALL_DIR)\same-dir.tst
+               - $(CP) $(BLD)\addpm.exe $(INSTALL_DIR)\bin
+               - $(CP) $(BLD)\runemacs.exe $(INSTALL_DIR)\bin
+               - $(ADDPM) $(INSTALL_DIR)
+               - $(DEL) ..\same-dir.tst
+               - $(DEL) $(INSTALL_DIR)\same-dir.tst
+               echo SameDirTest > $(INSTALL_DIR)\same-dir.tst
+               if not exist ..\same-dir.tst $(MAKE) -f makefile.nt real_install
+               - $(DEL) ..\same-dir.tst
+               - $(DEL) $(INSTALL_DIR)\same-dir.tst
 
 #
 # This installs executables from ..\bin into the installation directory
@@ -51,33 +111,45 @@ fast_install:
                $(CP) ..\lib-src\DOC $(INSTALL_DIR)\etc
                - mkdir $(INSTALL_DIR)\bin
                - $(CP) emacs.bat $(INSTALL_DIR)\bin
-               - del /q ..\same-dir.tst
-               - del /q $(INSTALL_DIR)\same-dir.tst
-               echo SameDirTest > ..\same-dir.tst
-               if not exist $(INSTALL_DIR)\same-dir.tst $(CP) ..\bin\emacs.exe $(INSTALL_DIR)\bin
-               if not exist $(INSTALL_DIR)\same-dir.tst $(CP) ..\bin\etags.exe $(INSTALL_DIR)\bin
-               if not exist $(INSTALL_DIR)\same-dir.tst $(CP) ..\bin\ctags.exe $(INSTALL_DIR)\bin
-               if not exist $(INSTALL_DIR)\same-dir.tst nmake -f $(MAKE) real_install
-               - del /q ..\same-dir.tst
-               - del /q $(INSTALL_DIR)\same-dir.tst
+               - $(CP) $(BLD)\addpm.exe $(INSTALL_DIR)\bin
+               - $(CP) $(BLD)\runemacs.exe $(INSTALL_DIR)\bin
+               - $(DEL) ..\same-dir.tst
+               - $(DEL) $(INSTALL_DIR)\same-dir.tst
+               echo SameDirTest > $(INSTALL_DIR)\same-dir.tst
+               if not exist ..\same-dir.tst $(CP) ..\bin\emacs.exe $(INSTALL_DIR)\bin
+               if not exist ..\same-dir.tst $(CP) ..\bin\etags.exe $(INSTALL_DIR)\bin
+               if not exist ..\same-dir.tst $(CP) ..\bin\ctags.exe $(INSTALL_DIR)\bin
+               if not exist ..\same-dir.tst nmake -f $(MAKE) real_install
+               - $(DEL) ..\same-dir.tst
+               - $(DEL) $(INSTALL_DIR)\same-dir.tst
 
 real_install:
-               - del /q ..\same-dir.tst
-               - del /q $(INSTALL_DIR)\same-dir.tst
-               echo SameDirTest > ..\same-dir.tst
+               - $(DEL) ..\same-dir.tst
+               - $(DEL) $(INSTALL_DIR)\same-dir.tst
+               echo SameDirTest > $(INSTALL_DIR)\same-dir.tst
                - mkdir $(INSTALL_DIR)\etc
                - mkdir $(INSTALL_DIR)\info
                - mkdir $(INSTALL_DIR)\lock
                - mkdir $(INSTALL_DIR)\data
-               if not exist $(INSTALL_DIR)\nt\same-dir.tst $(CP_DIR) ..\etc $(INSTALL_DIR)\etc
-               if not exist $(INSTALL_DIR)\nt\same-dir.tst $(CP_DIR) ..\info $(INSTALL_DIR)\info
-               - del /q ..\same-dir.tst
-               - del /q $(INSTALL_DIR)\same-dir.tst
+               if not exist ..\same-dir.tst $(CP_DIR) ..\etc $(INSTALL_DIR)\etc
+               if not exist ..\same-dir.tst $(CP_DIR) ..\info $(INSTALL_DIR)\info
+               - $(DEL) ..\same-dir.tst
+               - $(DEL) $(INSTALL_DIR)\same-dir.tst
 
 #
 # Maintenance
 # 
-clean:;                - del /q /s *~
+CLEAN_CMD      = $(MAKE) -f makefile.nt clean
+clean:;                - $(DEL) *~ *.pdb
                - $(DEL_TREE) deleted
+               - $(DEL_TREE) $(OBJDIR)
                - $(DEL_TREE) ..\bin
-               for %%f in ( $(SUBDIRS) ) do cd ..\%%f & $(MAKE) -f makefile.nt clean
+               - $(DEL) ..\etc\DOC ..\etc\DOC-X
+               - $(DEL) emacs.bat
+               cd ..\lib-src
+               $(CLEAN_CMD)
+               cd ..\src
+               $(CLEAN_CMD)
+               cd ..\lisp
+               $(CLEAN_CMD)
+               cd ..\nt