summaryrefslogtreecommitdiff
path: root/nt
diff options
context:
space:
mode:
authorGeoff Voelker <voelker@cs.washington.edu>1995-05-26 05:10:24 +0000
committerGeoff Voelker <voelker@cs.washington.edu>1995-05-26 05:10:24 +0000
commitb1f79b75d5f54670036ebbeb1cd44808ddad079e (patch)
tree4fe4de0c82b39c94b305274f85fd993e868260a9 /nt
parent7d0b2581e39d98f52f91767c2b02859846ca870d (diff)
downloademacs-b1f79b75d5f54670036ebbeb1cd44808ddad079e.tar.gz
(ARCH): New definition.
(CPU,CONFIG_H,OS_TYPE): Defined. (INCLUDE,LIB): Checked if valid. (ntwin32.mak): Included. (AR,CC,LINK): New definition. (ADVAPI32,libc,BASE_LIBS): Defined. (SYS_LDFLAGS): New definition. Update comments and preprocessor conditionals. (SYS_LIB_DIR,SYS_INC_DIR): Undefined.
Diffstat (limited to 'nt')
-rw-r--r--nt/makefile.def157
1 files changed, 112 insertions, 45 deletions
diff --git a/nt/makefile.def b/nt/makefile.def
index f1cfd80e6eb..ee7de6c2a81 100644
--- a/nt/makefile.def
+++ b/nt/makefile.def
@@ -21,44 +21,106 @@
# BEGIN CONFIGURATION
#
+# Set INSTALL_DIR to be the directory into which you want emacs installed.
#
-# Set ARCH to the architecture on which you're building (i386, mips, alpha).
-# Set SYS_INC_DIR and SYS_LIB_DIR to your system include and library dirs.
-#
-
-ARCH = mips
-SYS_INC_DIR = C:\mstools\h
-SYS_LIB_DIR = C:\mstools\lib
-
-# Set this to be the directory into which you want emacs installed
-INSTALL_DIR = C:\emacs
-
-# May need to be cl386.exe when using the SDK on an x86.
-CC = cl.exe
-
-# May need to be lib32.exe on NT 3.1, lib.exe on NT 3.5
-AR = lib32.exe
-
-MAKE = nmake.exe
-LINK = link32.exe
-
-# If you are using VC 2.0, define COMPAT_LIB (only tested on i386)
-#COMPAT_LIB = $(SYS_LIB_DIR)\oldnames.lib
-
-CVTRES = cvtres.exe
+!ifndef INSTALL_DIR
+INSTALL_DIR = C:\emacs
+!endif
#
# END CONFIGURATION
#
-# You shouldn't have to change any of the below to get emacs to build and
-# install on your system. If you did have to make changes, let me know.
+
+# Check that the INCLUDE and LIB environment variables are set.
+#
+!ifndef INCLUDE
+!error The INCLUDE environment variable needs to be set.
+!endif
+!ifndef LIB
+!error The LIB environment variable needs to be set.
+!endif
+
+# Determine the architecture we're running on.
+# Define ARCH for our purposes;
+# Define CPU for use by ntwin32.mak;
+# Define CONFIG_H to the appropriate config.h for the system;
#
+!ifdef PROCESSOR_ARCHITECTURE
+# We're on Windows NT
+CPU = $(PROCESSOR_ARCHITECTURE)
+CONFIG_H = config.nt
+OS_TYPE = winnt
+! if "$(PROCESSOR_ARCHITECTURE)" == "x86"
+ARCH = i386
+CPU = i386
+! else
+! if "$(PROCESSOR_ARCHITECTURE)" == "MIPS"
+ARCH = mips
+! else
+! if "$(PROCESSOR_ARCHITECTURE)" == "ALPHA"
+ARCH = alpha
+! else
+! if "$(PROCESSOR_ARCHITECTURE)" == "PPC"
+ARCH = ppc
+! else
+!error Unknown architecture type "$(PROCESSOR_ARCHITECTURE)"
+! endif
+! endif
+! endif
+! endif
+!else
+# We're on Windows 95
+ARCH = i386
+CPU = i386
+CONFIG_H = config.w95
+OS_TYPE = win95
+!endif
+
+# Include ntwin32.mak. So far, this file seems to be supported by every
+# Microsoft compiler on NT and Win95 and properly defines the executable
+# names and libraries necessary to build Emacs. I do not have access
+# to any other vendor compilers, so I do not know if they supply this
+# file, too. For now I'll assume that they do.
+#
+!include <ntwin32.mak>
-INC = -I. -I$(SYS_INC_DIR) -I$(SYS_INC_DIR)\crt
+# Using cvtres is necessary on NT 3.10 and doesn't hurt on later platforms.
+CVTRES = cvtres.exe
+AR = $(implib)
+# The assignment $(CC) = $(cc) fails even though variables are case sensitive.
+LINK_TMP = $(link)
+LINK = $(LINK_TMP)
+CC_TMP = $(cc)
+CC = $(CC_TMP)
+
+# advapi32.lib is left off of $(baselibs) on NT 3.10
+!if "$(baselibs)" == "kernel32.lib "
+ADVAPI32 = advapi32.lib
+!else
+ADVAPI32 =
+!endif
+
+# Older ntwin32.mak files do not define libc; do it for them.
+!ifndef libc
+libc = libc.lib
+!endif
+
+# The base libraries for compiling Emacs on NT. With MSVC, this should
+# include oldnames.lib.
+BASE_LIBS = $(libc) $(baselibs)
+
+# We want any debugging info in the executable.
+!if "$(LINK)" == "link32"
+SYS_LDFLAGS =
+!else
+SYS_LDFLAGS = -pdb:none -release -incremental:no
+!endif
+
+INC = -I.
CFLAGS = -nologo $(INC) $(ARCH_CFLAGS) $(LOCAL_FLAGS) -DWIN32_LEAN_AND_MEAN -D$(ARCH)
OBJDIR = obj
-$(OBJDIR):; -mkdir $(OBJDIR)
+$(OBJDIR):; -mkdir $(OBJDIR)
BLD = $(OBJDIR)\$(ARCH)
$(BLD): $(OBJDIR)
-mkdir $(BLD)
@@ -69,24 +131,29 @@ CP_DIR = xcopy /fried
# This is completely braindamaged, but it's the only routine known to be there
DEL_TREE = echo y | rmdir /s
-!IF "$(ARCH)" == "i386"
+!if "$(ARCH)" == "i386"
ARCH_CFLAGS = -nologo -D_X86_=1 -c -Zel -W2 -H63 -G3d -Zi -Od
-ARCH_LDFLAGS = -align:0x1000
+ARCH_LDFLAGS = -align:0x1000 $(SYS_LDFLAGS)
-!ELSE
-!IF "$(ARCH)" == "mips"
-CC = mcl.exe
-ARCH_CFLAGS = -D_MIPS_=1 -c -W2 -Zi -Od -Gt0 -D__stdcall= -D__cdecl=
-ARCH_LDFLAGS = -align:0x1000
+!else
+!if "$(ARCH)" == "mips"
+ARCH_CFLAGS = -D_MIPS_=1 -c -W2 -Zi -Od -Gt0
+ARCH_LDFLAGS = -align:0x1000 $(SYS_LDFLAGS)
-!ELSE
-!IF "$(ARCH)" == "alpha"
-CC = claxp.exe
+!else
+!if "$(ARCH)" == "alpha"
ARCH_CFLAGS = -D_ALPHA_=1 -c -Ze -Zi -W2 -D__stdcall= -D__cdecl=
-ARCH_LDFLAGS = -align:0x2000
-
-!ELSE
-!ERROR Unknown architecture type.
-!ENDIF
-!ENDIF
-!ENDIF
+ARCH_LDFLAGS = -align:0x2000 $(SYS_LDFLAGS)
+
+!else
+!if "$(ARCH)" == "ppc"
+# These flags are a guess...if they don't work, please send me mail.
+ARCH_CFLAGS = -D_PPC_=1 -c -Ze -Zi -W2 -Od
+ARCH_LDFLAGS = -align:0x1000 $(SYS_LDFLAGS)
+
+!else
+!ERROR Unknown architecture type "$(ARCH)".
+!endif
+!endif
+!endif
+!endif