(M13534): Unify U+65A4.
[chise/xemacs-chise.git-] / nt / xemacs.mak
index 7331255..e04f1c3 100644 (file)
@@ -129,12 +129,18 @@ DEBUG_XEMACS=0
 !if !defined(USE_UNION_TYPE)
 USE_UNION_TYPE=0
 !endif
+!if !defined(USE_MINITAR)
+USE_MINITAR=1
+!endif
 !if !defined(USE_MINIMAL_TAGBITS)
 USE_MINIMAL_TAGBITS=0
 !endif
 !if !defined(USE_INDEXED_LRECORD_IMPLEMENTATION)
 USE_INDEXED_LRECORD_IMPLEMENTATION=0
 !endif
+!if !defined(USE_PORTABLE_DUMPER)
+USE_PORTABLE_DUMPER=0
+!endif
 !if !defined(GUNG_HO)
 GUNG_HO=0
 !endif
@@ -341,6 +347,10 @@ TAGBITS_DEFINES=-DUSE_MINIMAL_TAGBITS
 LRECORD_DEFINES=-DUSE_INDEXED_LRECORD_IMPLEMENTATION
 !endif
 !if $(USE_UNION_TYPE)
+!if $(USE_PORTABLE_DUMPER)
+DUMPER_DEFINES=-DPDUMP
+!endif
+
 UNION_DEFINES=-DUSE_UNION_TYPE
 !endif
 
@@ -359,7 +369,7 @@ PATH_DEFINES=-DPATH_PREFIX=\"$(PATH_PREFIX)\"
 INCLUDES=$(X_INCLUDES) $(MSW_INCLUDES) -I$(XEMACS)\nt\inc -I$(XEMACS)\src -I$(XEMACS)\lwlib
 
 DEFINES=$(X_DEFINES) $(MSW_DEFINES) $(MULE_DEFINES) \
-       $(TAGBITS_DEFINES) $(LRECORD_DEFINES) $(UNION_DEFINES) \
+       $(TAGBITS_DEFINES) $(LRECORD_DEFINES) $(UNION_DEFINES) $(DUMPER_DEFINES)\
        -DWIN32 -D_WIN32 -DWIN32_LEAN_AND_MEAN -DWINDOWSNT -Demacs \
        -DHAVE_CONFIG_H $(PROGRAM_DEFINES) $(PATH_DEFINES)
 
@@ -417,17 +427,19 @@ CONFIG_VALUES = $(LIB_SRC)\config.values
 
 # Inferred rule
 {$(LIB_SRC)}.c{$(LIB_SRC)}.exe :
-       @cd $(LIB_SRC)
+       cd $(LIB_SRC)
        $(CCV) -I. -I$(XEMACS)/src -I$(XEMACS)/nt/inc $(LIB_SRC_DEFINES) $(CFLAGS) -Fe$@ $** -link -incremental:no
-       @cd $(NT)
+       cd $(NT)
 
 # Individual dependencies
 ETAGS_DEPS = $(LIB_SRC)/getopt.c $(LIB_SRC)/getopt1.c $(LIB_SRC)/../src/regex.c
 $(LIB_SRC)/etags.exe : $(LIB_SRC)/etags.c $(ETAGS_DEPS)
 $(LIB_SRC)/movemail.exe: $(LIB_SRC)/movemail.c $(LIB_SRC)/pop.c $(ETAGS_DEPS)
-       @cd $(LIB_SRC)
+       cd $(LIB_SRC)
        $(CCV) -I. -I$(XEMACS)/src -I$(XEMACS)/nt/inc $(LIB_SRC_DEFINES) $(CFLAGS) -Fe$@ $** wsock32.lib -link -incremental:no
-       @cd $(NT)
+       cd $(NT)
+$(LIB_SRC)/minitar.exe : $(NT)/minitar.mak $(NT)/minitar.c
+       nmake -nologo -f minitar.mak ZLIB="$(ZLIB_DIR)" NT="$(NT)" LIB_SRC="$(LIB_SRC)"
 
 LIB_SRC_TOOLS = \
        $(LIB_SRC)/make-docfile.exe     \
@@ -437,6 +449,14 @@ LIB_SRC_TOOLS = \
        $(LIB_SRC)/sorted-doc.exe       \
        $(LIB_SRC)/wakeup.exe           \
        $(LIB_SRC)/etags.exe            
+!if $(USE_MINITAR)
+LIB_SRC_TOOLS = \
+       $(LIB_SRC_TOOLS) \
+       $(LIB_SRC)/minitar.exe
+!endif
+
+# Shorthand target
+minitar: $(LIB_SRC)/minitar.exe
 
 #------------------------------------------------------------------------------
 
@@ -861,7 +881,7 @@ TEMACS_OBJS= \
 # Rules
 
 .SUFFIXES:
-.SUFFIXES:     .c .texi
+.SUFFIXES:     .c .obj .texi .info
 
 # nmake rule
 !if $(DEBUG_XEMACS)
@@ -901,7 +921,7 @@ $(OUTDIR)\xemacs.res: xemacs.rc
 
 # Section handling automated tests starts here
 
-SRCDIR=..\src
+SRCDIR=$(MAKEDIR)\..\src
 PROGNAME=$(SRCDIR)\xemacs.exe
 blddir=$(MAKEDIR:\=\\)\\..
 temacs_loadup=$(TEMACS) -batch -l $(SRCDIR)/../lisp/loadup.el
@@ -926,7 +946,10 @@ check-temacs:
 # Section handling automated tests ends here
 
 # Section handling info starts here
-MAKEINFO=$(PROGNAME) -no-site-file -no-init-file -batch -l texinfmt -f batch-texinfo-format
+
+!if !defined(MAKEINFO)
+MAKEINFO=$(PROGNAME) -vanilla -batch -l texinfmt -f batch-texinfo-format
+!endif
 
 MANDIR = $(XEMACS)\man
 INFODIR = $(XEMACS)\info
@@ -948,12 +971,10 @@ INFO_FILES= \
        $(INFODIR)\internals.info
 
 {$(MANDIR)}.texi{$(INFODIR)}.info:
+       cd $(MANDIR)
        $(MAKEINFO) $**
 
-$(INFODIR)\xemacs.info:        $(MANDIR)\xemacs\xemacs.texi
-       $(MAKEINFO) $**
-
-$(MANDIR)\xemacs\xemacs.texi: \
+XEMACS_SRCS = \
        $(MANDIR)\xemacs\abbrevs.texi \
        $(MANDIR)\xemacs\basic.texi \
        $(MANDIR)\xemacs\buffers.texi \
@@ -965,13 +986,13 @@ $(MANDIR)\xemacs\xemacs.texi: \
        $(MANDIR)\xemacs\entering.texi \
        $(MANDIR)\xemacs\files.texi \
        $(MANDIR)\xemacs\fixit.texi \
+       $(MANDIR)\xemacs\frame.texi \
        $(MANDIR)\xemacs\glossary.texi \
        $(MANDIR)\xemacs\gnu.texi \
        $(MANDIR)\xemacs\help.texi \
        $(MANDIR)\xemacs\indent.texi \
        $(MANDIR)\xemacs\keystrokes.texi \
        $(MANDIR)\xemacs\killing.texi \
-       $(MANDIR)\xemacs\\xemacs.texi \
        $(MANDIR)\xemacs\m-x.texi \
        $(MANDIR)\xemacs\major.texi \
        $(MANDIR)\xemacs\mark.texi \
@@ -979,25 +1000,23 @@ $(MANDIR)\xemacs\xemacs.texi: \
        $(MANDIR)\xemacs\mini.texi \
        $(MANDIR)\xemacs\misc.texi \
        $(MANDIR)\xemacs\mouse.texi \
+       $(MANDIR)\xemacs\mule.texi \
        $(MANDIR)\xemacs\new.texi \
+       $(MANDIR)\xemacs\packages.texi \
        $(MANDIR)\xemacs\picture.texi \
        $(MANDIR)\xemacs\programs.texi \
        $(MANDIR)\xemacs\reading.texi \
        $(MANDIR)\xemacs\regs.texi \
-       $(MANDIR)\xemacs\frame.texi \
        $(MANDIR)\xemacs\search.texi \
        $(MANDIR)\xemacs\sending.texi \
+       $(MANDIR)\xemacs\startup.texi \
        $(MANDIR)\xemacs\text.texi \
        $(MANDIR)\xemacs\trouble.texi \
        $(MANDIR)\xemacs\undo.texi \
-       $(MANDIR)\xemacs\windows.texi
+       $(MANDIR)\xemacs\windows.texi \
+       $(MANDIR)\xemacs\xemacs.texi
 
-
-$(INFODIR)\lispref.info:       $(MANDIR)\lispref\lispref.texi
-       copy $(MANDIR)\lispref\index.perm $(MANDIR)\lispref\index.texi
-       $(MAKEINFO) $**
-
-$(MANDIR)\lispref\lispref.texi: \
+LISPREF_SRCS = \
        $(MANDIR)\lispref\abbrevs.texi \
        $(MANDIR)\lispref\annotations.texi \
        $(MANDIR)\lispref\back.texi \
@@ -1008,10 +1027,12 @@ $(MANDIR)\lispref\lispref.texi: \
        $(MANDIR)\lispref\compile.texi \
        $(MANDIR)\lispref\consoles-devices.texi \
        $(MANDIR)\lispref\control.texi \
+       $(MANDIR)\lispref\customize.texi \
        $(MANDIR)\lispref\databases.texi \
        $(MANDIR)\lispref\debugging.texi \
        $(MANDIR)\lispref\dialog.texi \
        $(MANDIR)\lispref\display.texi \
+       $(MANDIR)\lispref\dragndrop.texi \
        $(MANDIR)\lispref\edebug-inc.texi \
        $(MANDIR)\lispref\edebug.texi \
        $(MANDIR)\lispref\errors.texi \
@@ -1025,12 +1046,12 @@ $(MANDIR)\lispref\lispref.texi: \
        $(MANDIR)\lispref\hash-tables.texi \
        $(MANDIR)\lispref\help.texi \
        $(MANDIR)\lispref\hooks.texi \
-       $(MANDIR)\lispref\index.perm \
-       $(MANDIR)\lispref\index.unperm \
+       $(MANDIR)\lispref\index.texi \
        $(MANDIR)\lispref\internationalization.texi \
        $(MANDIR)\lispref\intro.texi \
        $(MANDIR)\lispref\keymaps.texi \
        $(MANDIR)\lispref\ldap.texi \
+       $(MANDIR)\lispref\lispref.texi \
        $(MANDIR)\lispref\lists.texi \
        $(MANDIR)\lispref\loading.texi \
        $(MANDIR)\lispref\locals.texi \
@@ -1062,37 +1083,62 @@ $(MANDIR)\lispref\lispref.texi: \
        $(MANDIR)\lispref\tooltalk.texi \
        $(MANDIR)\lispref\variables.texi \
        $(MANDIR)\lispref\windows.texi \
-       $(MANDIR)\lispref\x-windows.texi \
-       $(MANDIR)\lispref\index.unperm \
-       $(MANDIR)\lispref\index.perm
-
+       $(MANDIR)\lispref\x-windows.texi
 
-$(INFODIR)\new-users-guide.info:       $(MANDIR)\new-users-guide\new-users-guide.texi
-       $(MAKEINFO) $**
+INTERNALS_SRCS = \
+       $(MANDIR)\internals\internals.texi \
+       $(MANDIR)\internals\index.texi
 
-$(MANDIR)\new-users-guide\new-users-guide.texi: \
+NEW_USERS_GUIDE_SRCS = \
        $(MANDIR)\new-users-guide\custom1.texi \
-       $(MANDIR)\new-users-guide\files.texi \
-       $(MANDIR)\new-users-guide\region.texi \
        $(MANDIR)\new-users-guide\custom2.texi \
-       $(MANDIR)\new-users-guide\help.texi \
-       $(MANDIR)\new-users-guide\search.texi \
        $(MANDIR)\new-users-guide\edit.texi \
+       $(MANDIR)\new-users-guide\enter.texi \
+       $(MANDIR)\new-users-guide\files.texi \
+       $(MANDIR)\new-users-guide\help.texi \
        $(MANDIR)\new-users-guide\modes.texi \
-       $(MANDIR)\new-users-guide\xmenu.texi \
-       $(MANDIR)\new-users-guide\enter.texi
-
-
-$(INFODIR)\internals.info:     $(MANDIR)\internals\internals.texi
-       copy $(MANDIR)\internals\index.perm $(MANDIR)\internals\index.texi
-       $(MAKEINFO) $**
-
-$(MANDIR)\internals\internals.texi: \
-       $(MANDIR)\internals\index.unperm \
-       $(MANDIR)\internals\index.perm
-
-
-info:  $(INFO_FILES)
+       $(MANDIR)\new-users-guide\new-users-guide.texi \
+       $(MANDIR)\new-users-guide\region.texi \
+       $(MANDIR)\new-users-guide\search.texi \
+       $(MANDIR)\new-users-guide\xmenu.texi
+
+$(INFODIR)\xemacs.info: $(XEMACS_SRCS)
+       cd $(MANDIR)\xemacs
+       $(MAKEINFO) xemacs.texi
+       cd ..
+
+
+$(INFODIR)\lispref.info: $(LISPREF_SRCS)
+       cd $(MANDIR)\lispref
+       $(MAKEINFO) lispref.texi
+       cd ..
+
+$(INFODIR)\internals.info: $(INTERNALS_SRCS)
+       cd $(MANDIR)\internals
+       $(MAKEINFO) internals.texi
+       cd ..
+
+$(INFODIR)\new-users-guide.info: $(NEW_USERS_GUIDE_SRCS)
+       cd $(MANDIR)\new-users-guide
+       $(MAKEINFO) new-users-guide.texi
+       cd ..
+
+info:  makeinfo-test $(INFO_FILES)
+
+makeinfo-test:
+       @<<makeinfo_test.bat
+@echo off
+if exist "$(MAKEINFO)" goto test_done
+@"$(PROGNAME)" -batch -vanilla -eval "(condition-case nil (require (quote texinfo)) (t (kill-emacs 1)))"
+@if not errorlevel 1 goto suggest_makeinfo
+@echo XEmacs `info' cannot be built!
+@echo Install XEmacs package `texinfo' (see README.packages).
+:suggest_makeinfo
+@echo Consider specifying path to makeinfo program: MAKEINFO=path
+@echo as this will build info docs faster than XEmacs using `texinfo'.
+@if errorlevel 1 exit 1
+:test_done
+<<NOKEEP
 
 # Section handling info ends here
 
@@ -1116,6 +1162,7 @@ $(DOC): $(LIB_SRC)\make-docfile.exe
        $(LIB_SRC)\make-docfile.exe -a $(DOC) -d $(TEMACS_SRC) $(DOC_SRC9)
 
 update-elc:
+       set EMACSBOOTSTRAPMODULEPATH=$(MODULES)
        set EMACSBOOTSTRAPLOADPATH=$(LISP);$(PACKAGE_PATH)
        set EMACSBOOTSTRAPMODULEPATH=$(MODULES)
        $(TEMACS) -batch -l $(TEMACS_DIR)\..\lisp\update-elc.el
@@ -1127,7 +1174,7 @@ dump-xemacs: $(TEMACS)
        cd $(TEMACS_DIR)
        set EMACSBOOTSTRAPLOADPATH=$(LISP);$(PACKAGE_PATH)
        -1 $(TEMACS) -batch -l $(TEMACS_DIR)\..\lisp\loadup.el dump
-       @cd $(NT)
+       cd $(NT)
        @if not exist $(TEMACS_DIR)\SATISFIED nmake -nologo -f xemacs.mak $@
 
 #------------------------------------------------------------------------------
@@ -1137,10 +1184,11 @@ all:    $(XEMACS)\Installation $(OUTDIR)\nul $(LASTFILE) $(LWLIB) \
        $(LIB_SRC_TOOLS) $(RUNEMACS) $(TEMACS) update-elc $(DOC) dump-xemacs \
        $(LISP)/auto-autoloads.el $(LISP)/custom-load.el info
 
-temacs: $(TEMACS)
+temacs: $(LASTFILE) $(TEMACS)
 
 # use this rule to install the system
 install:       all
+       cd $(NT)
        @echo Installing in $(INSTALL_DIR) ...
        @echo PlaceHolder > PlaceHolder
        @xcopy /q PROBLEMS "$(INSTALL_DIR)\"
@@ -1199,10 +1247,12 @@ distclean:
        cd $(LISP)
        $(DEL) /s /q *.bak *.elc *.orig *.rej
        cd $(INFODIR)
-       $(DEL) *.info* $(MANDIR)\internals\index.texi $(MANDIR)\lispref\index.texi
+       $(DEL) *.info*
 
 depend:
-       mkdepend -f xemacs.mak -p$(OUTDIR)\ -o.obj -w9999 -- $(TEMACS_CPP_FLAGS) --  $(DOC_SRC1) $(DOC_SRC2) $(DOC_SRC3) $(DOC_SRC4) $(DOC_SRC5) $(DOC_SRC6) $(DOC_SRC7) $(DOC_SRC8) $(DOC_SRC9) $(LASTFILE_SRC)\lastfile.c $(LIB_SRC)\make-docfile.c $(LIB_SRC)\run.c
+       cd $(SRCDIR)
+       perl ./make-src-depend > depend.tmp
+       perl -MFile::Compare -e "compare('depend.tmp', 'depend') && rename('depend.tmp', 'depend') or unlink('depend.tmp')"
 
 $(XEMACS)\Installation:
        @type > $(XEMACS)\Installation <<
@@ -1292,6 +1342,9 @@ XEmacs $(XEMACS_VERSION_STRING) $(xemacs_codename:"=\") configured for `$(EMACS_
 !if $(USE_UNION_TYPE)
   Using union type for Lisp object storage.
 !endif
+!if $(USE_PORTABLE_DUMPER)
+  Using portable dumper.
+!endif
 !if $(DEBUG_XEMACS)
   Compiling in extra debug checks. XEmacs will be slow!
 !endif
@@ -1305,6 +1358,7 @@ XEmacs $(XEMACS_VERSION_STRING) $(xemacs_codename:"=\") configured for `$(EMACS_
 VANILLA=-vanilla
 FORCE:
 $(LISP)\auto-autoloads.el:     FORCE
+       @$(DEL) $(LISP)\auto-autoloads.el
        $(PROGNAME) $(VANILLA) -batch \
                -l autoload -f batch-update-directory $(LISP)
        $(PROGNAME) $(VANILLA) -batch \