]> code.delx.au - gnu-emacs/blobdiff - lib-src/makefile.w32-in
($(BLD)/emacsclient.$(O)): Use CFLAGS.
[gnu-emacs] / lib-src / makefile.w32-in
index bfda0f25d5fac396212e39119f36a80ff8d22217..9b26146a5750e7dfd95d2e03618bbe7c263664b8 100644 (file)
@@ -1,6 +1,6 @@
 #  -*- Makefile -*- for GNU Emacs on the Microsoft W32 API.
 #  Copyright (C) 2000, 2001, 2002, 2003, 2004,
-#                2005 Free Software Foundation, Inc.
+#                2005, 2006 Free Software Foundation, Inc.
 #
 #  This file is part of GNU Emacs.
 #
@@ -20,7 +20,7 @@
 #  Boston, MA 02110-1301, USA.
 #
 
-ALL          = make-docfile hexl ctags etags movemail ebrowse
+ALL = make-docfile hexl ctags etags movemail ebrowse sorted-doc digest-doc emacsclient
 
 .PHONY: $(ALL)
 
@@ -30,15 +30,9 @@ LOCAL_FLAGS  = -DWINDOWSNT -DDOS_NT -DSTDC_HEADERS=1 -DNO_LDAV=1 \
 
 # don't know what (if) to do with these yet...
 #
-#              $(BLD)/sorted-doc.exe   \
-#              $(BLD)/env.exe          \
 #              $(BLD)/server.exe       \
 #              $(BLD)/emacstool.exe    \
-#              $(BLD)/leditcfns.exe    \
-#              $(BLD)/emacsclient.exe  \
 #              $(BLD)/cvtmail.exe      \
-#              $(BLD)/digest-doc.exe   \
-#              $(BLD)/test-distrib.exe \
 
 LIBS         = $(BASE_LIBS) $(ADVAPI32)
 
@@ -48,6 +42,12 @@ $(BLD)/hexl.exe:             $(BLD)/hexl.$(O)
                $(LINK) $(LINK_OUT)$@ $(LINK_FLAGS) $(BLD)/hexl.$(O) $(LIBS)
 $(BLD)/fakemail.exe:           $(BLD)/fakemail.$(O) $(BLD)/ntlib.$(O)
                $(LINK) $(LINK_OUT)$@ $(LINK_FLAGS) $(BLD)/fakemail.$(O) $(BLD)/ntlib.$(O) $(LIBS)
+$(BLD)/sorted-doc.exe:         $(BLD)/sorted-doc.$(O)
+               $(LINK) $(LINK_OUT)$@ $(LINK_FLAGS) $(BLD)/sorted-doc.$(O) $(LIBS)
+$(BLD)/digest-doc.exe:         $(BLD)/digest-doc.$(O)
+               $(LINK) $(LINK_OUT)$@ $(LINK_FLAGS) $(BLD)/digest-doc.$(O) $(LIBS)
+$(BLD)/test-distrib.exe: $(BLD)/test-distrib.$(O)
+               $(LINK) $(LINK_OUT)$@ $(LINK_FLAGS) $(BLD)/test-distrib.$(O) $(LIBS)
 
 make-docfile:  $(BLD) $(BLD)/make-docfile.exe
 ctags:         $(BLD) $(BLD)/ctags.exe
@@ -56,6 +56,12 @@ ebrowse:        $(BLD) $(BLD)/ebrowse.exe
 hexl:          $(BLD) $(BLD)/hexl.exe
 movemail:      $(BLD) $(BLD)/movemail.exe
 fakemail:      $(BLD) $(BLD)/fakemail.exe
+sorted-doc:    $(BLD) $(BLD)/sorted-doc.exe
+digest-doc:    $(BLD) $(BLD)/digest-doc.exe
+emacsclient:   $(BLD) $(BLD)/emacsclient.exe
+
+test-distrib:  $(BLD) $(BLD)/test-distrib.exe
+       "$(BLD)/test-distrib.exe" "$(SRC)/testfile"
 
 GETOPTOBJS = $(BLD)/getopt.$(O) $(BLD)/getopt1.$(O)
 GETOPTDEPS = $(GETOPTOBJS) getopt.h
@@ -68,6 +74,19 @@ $(BLD)/movemail.exe: $(MOVEMAILOBJS) getopt.h
 # put wsock32.lib before $(LIBS) to ensure we don't link to ws2_32.lib
                $(LINK) $(LINK_OUT)$@ $(LINK_FLAGS) $(MOVEMAILOBJS) $(WSOCK32) $(LIBS)
 
+ECLIENT_CFLAGS = -DWINDOWSNT -DHAVE_GETCWD -DHAVE_STRERROR -c
+ECLIENTOBJS =  $(BLD)/emacsclient.$(O) \
+               $(BLD)/getopt.$(O) \
+               $(BLD)/getopt1.$(O) \
+               $(BLD)/ntlib.$(O)
+
+$(BLD)/emacsclient.exe:                $(ECLIENTOBJS)
+# put wsock32.lib before $(LIBS) to ensure we don't link to ws2_32.lib
+               $(LINK) $(LINK_OUT)$@ $(LINK_FLAGS) $(ECLIENTOBJS) $(WSOCK32) $(LIBS)
+
+$(BLD)/emacsclient.$(O):       emacsclient.c
+               $(CC) $(CFLAGS) $(ECLIENT_CFLAGS) $(CC_OUT)$@ emacsclient.c
+
 ETAGSOBJ      = $(BLD)/etags.$(O) \
                $(BLD)/getopt.$(O) \
                $(BLD)/getopt1.$(O) \
@@ -114,15 +133,10 @@ $(BLD)/ctags.$(O): ctags.c
 #
 # don't know what to do with these yet...
 #
-# $(BLD)/sorted-doc.exe:       $(BLD)/sorted-doc.$(O)
-# $(BLD)/yow.exe:              $(BLD)/yow.$(O)
 # $(BLD)/emacstool.exe:        $(BLD)/emacstool.$(O)
-# $(BLD)/leditcfns.exe:        $(BLD)/leditcfns.$(O)
 # $(BLD)/server.exe:           $(BLD)/server.$(O)
 # $(BLD)/cvtmail.exe:          $(BLD)/cvtmail.$(O)
-# $(BLD)/digest-doc.exe:       $(BLD)/digest-doc.$(O)
 # $(BLD)/emacsclient.exe:      $(BLD)/emacsclient.$(O)
-# $(BLD)/test-distrib.exe:     $(BLD)/test-distrib.$(O)
 
 #
 # From ..\src\Makefile.in
@@ -154,7 +168,7 @@ obj=    sunfns.o dosfns.o msdos.o \
 #
 lispsource = ../lisp/
 
-MOUSE_SUPPORT = $(lispsource)select.elc $(lispsource)scroll-bar.elc $(lispsource)mouse.elc
+MOUSE_SUPPORT = $(lispsource)select.elc $(lispsource)scroll-bar.elc $(lispsource)mouse.elc $(lispsource)tooltip.elc
 WINNT_SUPPORT = $(lispsource)ls-lisp.elc $(lispsource)disp-table.elc $(lispsource)w32-fns.elc $(lispsource)dos-w32.elc $(lispsource)w32-vars.elc
 
 # lisp files that are loaded up on other platforms
@@ -166,33 +180,35 @@ lisp1= \
        $(lispsource)buff-menu.elc \
        $(lispsource)button.elc \
        $(lispsource)emacs-lisp/byte-run.elc \
+       $(lispsource)cus-face.elc \
        $(lispsource)cus-start.elc \
        $(lispsource)custom.elc \
        $(lispsource)emacs-lisp/backquote.elc \
        $(lispsource)emacs-lisp/lisp-mode.elc \
        $(lispsource)emacs-lisp/lisp.elc \
-       $(lispsource)env.elc \
-       $(lispsource)faces.elc \
-       $(lispsource)files.elc \
-       $(lispsource)format.elc \
        $(lispsource)facemenu.elc \
        $(MOUSE_SUPPORT) \
+       $(lispsource)faces.elc \
+       $(lispsource)files.elc \
        $(lispsource)emacs-lisp/float-sup.elc \
+       $(lispsource)format.elc \
        $(lispsource)frame.elc \
        $(lispsource)help.elc \
        $(lispsource)indent.elc \
        $(lispsource)isearch.elc \
+       $(lispsource)rfn-eshadow.elc \
        $(lispsource)loadup.el \
        $(lispsource)loaddefs.el \
        $(lispsource)bindings.elc \
        $(lispsource)emacs-lisp/map-ynp.elc \
-       $(lispsource)menu-bar.elc \
+       $(lispsource)env.elc \
        $(lispsource)international/mule.elc \
        $(lispsource)international/mule-conf.el \
        $(lispsource)international/mule-cmds.elc \
        $(lispsource)international/characters.elc \
        $(lispsource)international/ucs-tables.elc \
        $(lispsource)international/utf-8.elc \
+       $(lispsource)international/utf-16.elc \
        $(lispsource)international/latin-1.el \
        $(lispsource)international/latin-2.el \
        $(lispsource)international/latin-3.el \
@@ -200,6 +216,12 @@ lisp1= \
        $(lispsource)international/latin-5.el \
        $(lispsource)international/latin-8.el \
        $(lispsource)international/latin-9.el \
+       $(lispsource)fringe.elc \
+       $(lispsource)image.elc \
+       $(lispsource)international/fontset.elc \
+       $(lispsource)dnd.elc \
+       $(lispsource)mwheel.elc \
+       $(lispsource)tool-bar.elc \
        $(lispsource)case-table.elc
 
 lisp2 = \
@@ -207,6 +229,7 @@ lisp2 = \
        $(lispsource)language/cyrillic.elc \
        $(lispsource)language/indian.elc \
        $(lispsource)language/devanagari.el \
+       $(lispsource)language/kannada.el \
        $(lispsource)language/malayalam.el \
        $(lispsource)language/tamil.el \
        $(lispsource)language/english.el \
@@ -226,6 +249,7 @@ lisp2 = \
        $(lispsource)language/misc-lang.el \
        $(lispsource)language/utf-8-lang.el \
        $(lispsource)language/georgian.el \
+       $(lispsource)menu-bar.elc \
        $(lispsource)paths.el \
        $(lispsource)register.elc \
        $(lispsource)replace.elc \
@@ -234,11 +258,16 @@ lisp2 = \
        $(lispsource)subr.elc \
        $(lispsource)term/tty-colors.elc \
        $(lispsource)font-core.elc \
+       $(lispsource)emacs-lisp/syntax.elc \
+       $(lispsource)font-lock.elc \
+       $(lispsource)jit-lock.elc \
        $(lispsource)textmodes/fill.elc \
        $(lispsource)textmodes/page.elc \
        $(lispsource)textmodes/paragraphs.elc \
        $(lispsource)textmodes/text-mode.elc \
+       $(lispsource)emacs-lisp/timer.elc \
        $(lispsource)vc-hooks.elc \
+       $(lispsource)jka-cmpr-hook.elc \
        $(lispsource)ediff-hook.elc \
        $(VMS_SUPPORT) \
        $(MSDOS_SUPPORT) \
@@ -247,6 +276,15 @@ lisp2 = \
        $(lispsource)window.elc \
        $(lispsource)version.el
 
+# This is needed the first time we build the tree, since temacs.exe
+# does not exist yet, and the DOC rule needs it to rebuild DOC whenever
+# Emacs is rebuilt.
+../src/$(BLD)/temacs.exe:
+       - mkdir "../src/$(OBJDIR)"
+       - mkdir "../src/$(BLD)"
+       @echo temacs > temacs.exe
+       $(CP) temacs.exe ../src/$(BLD)
+       - $(DEL) temacs.exe
 
 DOC          = DOC
 $(DOC):                $(BLD) $(BLD)/make-docfile.exe ../src/$(BLD)/temacs.exe $(lisp1) $(lisp2)
@@ -278,6 +316,9 @@ install:    $(INSTALL_FILES)
                $(CP) $(BLD)/ctags.exe $(INSTALL_DIR)/bin
                $(CP) $(BLD)/hexl.exe $(INSTALL_DIR)/bin
                $(CP) $(BLD)/movemail.exe $(INSTALL_DIR)/bin
+               $(CP) $(BLD)/sorted-doc.exe $(INSTALL_DIR)/bin
+               $(CP) $(BLD)/digest-doc.exe $(INSTALL_DIR)/bin
+               $(CP) $(BLD)/emacsclient.exe $(INSTALL_DIR)/bin
                - mkdir "$(INSTALL_DIR)/etc"
                $(CP) $(DOC) $(INSTALL_DIR)/etc
 
@@ -300,9 +341,9 @@ cleanall:   clean
 # Headers we would preprocess if we could.
 #
 ../src/config.h:       ../nt/$(CONFIG_H)
-                       $(CP) $(ALL_DEPS) $@
-../src/paths.h:                ../nt/paths.h
-                       $(CP) $(ALL_DEPS) $@
+                       echo $(CONFIG_H) has changed.  Re-run configure.bat.
+                       exit -1
+
 getopt.h:              getopt_.h
                        $(CP) $(ALL_DEPS) $@
 
@@ -433,7 +474,10 @@ $(BLD)/qsort.$(O) : \
        $(SRC)/qsort.c
 
 $(BLD)/sorted-doc.$(O) : \
-       $(SRC)/sorted-doc.c
+       $(SRC)/sorted-doc.c \
+       $(EMACS_ROOT)/src/s/ms-w32.h \
+       $(EMACS_ROOT)/src/m/intel386.h \
+       $(EMACS_ROOT)/src/config.h \
 
 $(BLD)/tcp.$(O) : \
        $(SRC)/tcp.c
@@ -446,7 +490,3 @@ $(BLD)/timer.$(O) : \
        $(EMACS_ROOT)/src/s/ms-w32.h \
        $(EMACS_ROOT)/src/m/intel386.h \
        $(EMACS_ROOT)/lib-src/../src/config.h
-
-$(BLD)/yow.$(O) : \
-       $(SRC)/yow.c \
-       $(EMACS_ROOT)/lib-src/../src/paths.h