pull up r19869 from trunk
authorTom Yu <tlyu@mit.edu>
Fri, 28 Sep 2007 23:39:44 +0000 (23:39 +0000)
committerTom Yu <tlyu@mit.edu>
Fri, 28 Sep 2007 23:39:44 +0000 (23:39 +0000)
 r19869@cathode-dark-space:  jaltman | 2007-08-24 10:54:23 -0400
 ticket: new
 subject: NIM: version update
 component: windows

 Set the Network Identity Manager application version to 1.3.1 and the
 API version to 10.

ticket: 5690
version_fixed: 1.6.3

git-svn-id: svn://anonsvn.mit.edu/krb5/branches/krb5-1-6@20004 dc483132-0cff-0310-8789-dd5450dbe970

src/windows/identity/config/Makefile.w2k
src/windows/identity/config/Makefile.w32

index 7cdb3d5f5380a50e9e215640179e29db66b3a583..4d500ffb83e2438997946d3bd7bf426fa0910988 100644 (file)
-#\r
-#  Khimaira : Win32 configuration makefile\r
-#             This file will be included by all the makefiles\r
-#             in the build tree.\r
-#\r
-# Copyright (c) 2004,2005,2006 Massachusetts Institute of Technology\r
-# Copyright (c) 2006,2007 Secure Endpoints Inc.\r
-#\r
-# Permission is hereby granted, free of charge, to any person\r
-# obtaining a copy of this software and associated documentation files\r
-# (the "Software"), to deal in the Software without restriction,\r
-# including without limitation the rights to use, copy, modify, merge,\r
-# publish, distribute, sublicense, and/or sell copies of the Software,\r
-# and to permit persons to whom the Software is furnished to do so,\r
-# subject to the following conditions:\r
-#\r
-# The above copyright notice and this permission notice shall be\r
-# included in all copies or substantial portions of the Software.\r
-#\r
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,\r
-# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\r
-# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\r
-# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS\r
-# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\r
-# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
-# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\r
-# SOFTWARE.\r
-\r
-!ifndef KHIMAIRA_WIN32_CONFIG\r
-KHIMAIRA_WIN32_CONFIG=1\r
-\r
-# Environment Variables\r
-#  The following environment variables MUST be set:\r
-#   KH_ROOT : Root of the source tree.\r
-#   KH_BUILD: One of DEBUG or RETAIL\r
-#\r
-#  The following environment variables are optional:\r
-#   KH_RUNTIME: One of STATIC or DLL, specifies whether the CRT libs\r
-#               are linked statically or through MSVCRT.DLL.\r
-#   KH_AUXCFLAGS: Optional flags for CL\r
-#   KH_RELEASE: Release type.  One of OFFICIAL, PRERELEASE, PRIVATE or SPECIAL.\r
-#      OFFICIAL   : An official release of Khimaira\r
-#      PREPRELEASE: A beta/release candidate release\r
-#      PRIVATE    : Private build\r
-#      SPECIAL    : Special build.  Typically one with non-mainline patches.\r
-\r
-# Version info\r
-NETIDMGR_VERSION_MAJOR=1\r
-NETIDMGR_VERSION_MINOR=3\r
-NETIDMGR_VERSION_PATCH=0\r
-NETIDMGR_VERSION_AUX=0\r
-NETIDMGR_RELEASEDESC=\r
-\r
-# The API version.  This number must be incremented each time the API\r
-# changes.  Plugins specify the version of the API that they were\r
-# compiled against and the Module Manager uses the API numbers to\r
-# decide whether the plugin is safe to load or not.\r
-#\r
-# Changes to the API version numbers should be documented in\r
-# apiversion.txt at the root of the source tree.\r
-NETIDMGR_VERSION_API=9\r
-\r
-# Minimum backwards compatible version.  API versions from\r
-# NETIDMGR_VERSION_API_MINCOMPAT through NETIDMGR_VERSION_API\r
-# inclusive, are compatible with this version.\r
-NETIDMGR_VERSION_API_MINCOMPAT=5\r
-\r
-NETIDMGR_VERSION=$(NETIDMGR_VERSION_MAJOR).$(NETIDMGR_VERSION_MINOR).$(NETIDMGR_VERSION_PATCH).$(NETIDMGR_VERSION_AUX)\r
-NETIDMGR_VERSIONC=$(NETIDMGR_VERSION_MAJOR),$(NETIDMGR_VERSION_MINOR),$(NETIDMGR_VERSION_PATCH),$(NETIDMGR_VERSION_AUX)\r
-\r
-# Source information\r
-NETIDMGR_SRC_COMPANY_1033=Massachusetts Institute of Technology\r
-NETIDMGR_SRC_COPYRIGHT_1033=(C) 2005,2006 Massachusetts Institute of Technology\r
-\r
-# Choose the default build type if one is not set\r
-!if ("$(KH_BUILD)" != "DEBUG") && ("$(KH_BUILD)" != "RETAIL")\r
-!  if defined(NODEBUG) && "$(NODEBUG)"=="1"\r
-KH_BUILD=RETAIL\r
-!  else\r
-KH_BUILD=DEBUG\r
-!  endif\r
-!endif\r
-\r
-!if "$(KH_BUILD)"=="DEBUG" && defined(NODEBUG) && "$(NODEBUG)"=="1"\r
-! error The Khimaira build configuration is set for DEBUG while the Platform SDK build environment is set to RETAIL.\r
-!endif\r
-\r
-# The default release type is PRIVATE is no other type is specified\r
-!if ("$(KH_RELEASE)" != "OFFICIAL") && ("$(KH_RELEASE)" != "PRERELEASE") && ("$(KH_RELEASE)" != "PRIVATE") && ("$(KH_RELEASE)" != "SPECIAL")\r
-KH_RELEASE=PRIVATE\r
-!endif\r
-\r
-# Actual build environment settings\r
-\r
-# See what compiler we are using\r
-# TODO: Update this to support other compilers\r
-!if defined(MSVCVer) && "$(MSVCVer)"=="8.0"\r
-KH_CLVER=vc8\r
-!else\r
-KH_CLVER=vc7\r
-!endif\r
-\r
-# Check for required env vars\r
-!ifndef MODULE\r
-!      error MODULE must be specified\r
-!endif\r
-!ifndef KH_ROOT\r
-! ifndef PISMERE\r
-!   error Either KH_ROOT or PISMERE must be defined\r
-! else\r
-KH_ROOT=$(PISMERE)\athena\auth\krb5\src\windows\identity\r
-! endif\r
-!endif\r
-\r
-!ifdef NODEBUG\r
-OUTPRE_DBG=rel\r
-!else\r
-OUTPRE_DBG=dbg\r
-!endif\r
-OUTPRE1=obj\r
-OUTPRE2=$(OUTPRE1)\$(CPU)\r
-OUTPRE3=$(OUTPRE2)\$(OUTPRE_DBG)\r
-OUTPRE=$(OUTPRE3)^\\r
-\r
-\r
-\r
-# Output directory structure\r
-DESTROOT=$(KH_ROOT)\obj\r
-OBJROOT=$(KH_ROOT)\obj\r
-SRC=$(KH_ROOT)\r
-\r
-DESTDIR=$(DESTROOT)\$(CPU)\$(OUTPRE_DBG)\r
-OBJDIR=$(OBJROOT)\$(CPU)\$(OUTPRE_DBG)\r
-\r
-OBJ=$(OBJDIR)\$(MODULE)\r
-INCDIR=$(DESTDIR)\inc\r
-#BINDIR=$(DESTDIR)\bin\r
-BINDIR=$(KH_ROOT)\$(OUTPRE)\W2K\r
-#LIBDIR=$(DESTDIR)\lib\r
-LIBDIR=$(KH_ROOT)\$(OUTPRE)\W2K\r
-DOCDIR=$(DESTDIR)\doc\r
-\r
-# Source directories\r
-CONFDIR=$(SRC)\config\r
-\r
-# Setup environment for win32.mak\r
-\r
-!if "$(KH_BUILD)" == "RETAIL"\r
-NODEBUG=1\r
-!endif\r
-\r
-# Win32.mak\r
-APPVER=5.0\r
-TARGETOS=WINNT\r
-_WIN32_IE=0x0500\r
-_WIN32_WINNT=0x0500\r
-!include <Win32.Mak>\r
-\r
-# Program macros\r
-\r
-CD=cd\r
-RM=del /q\r
-MKDIR=mkdir\r
-RMDIR=rmdir\r
-ECHO=echo\r
-MAKECMD=nmake /nologo\r
-CP=copy /y\r
-LINK=link\r
-CCSV=perl $(SRC)\config\ccsv.pl\r
-MC=mc\r
-\r
-!ifdef KH_DOXYFULLPATH\r
-DOXYGEN=$(KH_DOXYFULLPATH)\r
-!else\r
-DOXYGEN=doxygen\r
-!endif\r
-\r
-!ifdef KH_HHCFULLPATH\r
-HHC=$(KH_HHCFULLPATH)\r
-!else\r
-HHC=hhc\r
-!endif\r
-\r
-!ifdef KH_KFWPATH\r
-KFWINCDIR=$(KH_KFWPATH)\inc\r
-kfwincflags = -I$(KFWINCDIR)\krb5 -I$(KFWINCDIR)\krb5\KerberosIV -I$(KFWINCDIR)\krb4 -I$(KFWINCDIR)\loadfuncs -I$(KFWINCDIR)\r
-KFWLIBDIR=$(KH_KFWPATH)\lib\$(CPU)\r
-!else if defined(PISMERE)\r
-KFWINCDIR=$(PISMERE)\athena\auth\krb5\src\include\r
-kfwincflags = -I$(KFWINCDIR) -I$(PISMERE)\athena\util\loadfuncs -I$(PISMERE)\athena\auth\krb5\src\include\kerberosIV -I$(PISMERE)\athena\auth\krb4\include\r
-KFWLIBDIR=$(PISMERE)\target\lib\$(CPU)\$(OUTPRE_DBG)\r
-!endif\r
-\r
-!ifdef KH_AFSPATH\r
-AFSINCDIR=$(KH_AFSPATH)\include\r
-AFSLIBDIR=$(KH_AFSPATH)\lib\r
-afsincflags=-I$(AFSINCDIR)\r
-!endif\r
-\r
-#EXTLIBDIR=$(SRC)\ext-lib\$(CPU)\r
-#EXTINCDIR=-I$(SRC)\ext-inc\r
-\r
-incflags= -I$(INCDIR) -I$(SRC)\include -I. -I$(OBJ) $(kfwincflags) $(afsincflags)\r
-rincflags= /i $(INCDIR) /i $(SRC)\include /i .\r
-khdefines=-DUNICODE -D_UNICODE\r
-khcwarn=/Wp64\r
-!ifndef KH_NO_WX\r
-khcwarn=$(khcwarn) /WX\r
-!endif\r
-\r
-!if "$(CPU)" == "i386"\r
-khdefines=$(khdefines) -D_USE_32BIT_TIME_T\r
-!endif\r
-\r
-#DEBUG_SYMBOLS\r
-ldebug=$(ldebug) /DEBUG\r
-cdebug=$(cdebug) -Os -Zi\r
-\r
-# Additionally, suppress conflicting default library directives that we\r
-# might pull in from external libraries.\r
-\r
-!ifndef NODEBUG\r
-lndeflibflag=/NODEFAULTLIB:MSVCRT\r
-!else\r
-lndeflibflag=/NODEFAULTLIB:MSVCRTD\r
-!endif\r
-\r
-khcflags=$(cdebug) $(cflags) $(incflags) $(khdefines) $(khcwarn)\r
-khlguiflags=$(ldebug) $(guilflags) $(lndeflibflag)\r
-khlconflags=$(ldebug) $(conlflags) $(lndeflibflag)\r
-khldllguiflags=$(ldebug) $(dlllflags) $(lndeflibflag)\r
-khldllconflags=$(ldebug) $(dlllflags) $(lndeflibflag)\r
-\r
-!if "$(KH_RUNTIME)" == "STATIC"\r
-khcflags=$(khcflags) $(cvarsmt)\r
-khlguiflags=$(khlguiflags) $(guilibsmt)\r
-khlconflags=$(khlconflags) $(conlibsmt)\r
-khldllguiflags=$(khldllguiflags) $(guilibsmt)\r
-khldllconflags=$(khldllconflags) $(conlibsmt)\r
-!else\r
-khcflags=$(khcflags) $(cvarsdll)\r
-khlguiflags=$(khlguiflags) $(guilibsdll)\r
-khlconflags=$(khlconflags) $(conlibsdll)\r
-khldllguiflags=$(khldllguiflags) $(guilibsdll)\r
-khldllconflags=$(khldllconflags) $(conlibsdll)\r
-!endif\r
-\r
-C2OBJ=$(CC) $(khcflags) $(KH_AUXCFLAGS) /Fo"$@" /c $**\r
-\r
-EXECONLINK=$(LINK) /NOLOGO $(khlconflags) /OUT:$@ $**\r
-\r
-EXEGUILINK=$(LINK) /NOLOGO $(khlguiflags) /OUT:$@ $**\r
-\r
-DLLCONLINK=$(LINK) /NOLOGO $(khldllconflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**\r
-\r
-DLLGUILINK=$(LINK) /NOLOGO $(khldllguiflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**\r
-\r
-DLLRESLINK=$(LINK) /NOLOGO /DLL /NOENTRY /MACHINE:$(PROCESSOR_ARCHITECTURE) /OUT:$@ $**\r
-\r
-RC2RES=$(RC) $(RFLAGS) $(rincflags) /fo $@ $**\r
-\r
-MC2RC=$(MC) $(MCFLAGS) -h $(OBJ)\ -m 1024 -r $(OBJ)\ -x $(OBJ)\ $**\r
-\r
-{}.c{$(OBJ)}.obj:\r
-       $(C2OBJ)\r
-\r
-{$(OBJ)}.c{$(OBJ)}.obj:\r
-       $(C2OBJ)\r
-\r
-{}.h{$(INCDIR)}.h:\r
-       $(CP) $** $@\r
-\r
-{}.rc{$(OBJ)}.res:\r
-       $(RC2RES)\r
-\r
-{$(OBJ)}.rc{$(OBJ)}.res:\r
-       $(RC2RES)\r
-\r
-clean::\r
-!if exist($(OBJ))\r
-       $(RM) $(OBJ)\\r
-!endif\r
-\r
-test::\r
-\r
-mkdirs::\r
-!if !exist($(LIBDIR))\r
-       $(MKDIR) $(LIBDIR)\r
-!endif\r
-!if !exist($(BINDIR))\r
-       $(MKDIR) $(BINDIR)\r
-!endif\r
-!if !exist($(OBJ))\r
-       $(MKDIR) $(OBJ)\r
-!endif\r
-\r
-TAGFILE = $(SRC)\TAGS\r
-\r
-etag::\r
-       etags -o $(TAGFILE) -a *.c *.h\r
-\r
-.SUFFIXES: .h\r
-\r
-!endif\r
+#
+#  Khimaira : Win32 configuration makefile
+#             This file will be included by all the makefiles
+#             in the build tree.
+#
+# Copyright (c) 2004,2005,2006 Massachusetts Institute of Technology
+# Copyright (c) 2006,2007 Secure Endpoints Inc.
+#
+# Permission is hereby granted, free of charge, to any person
+# obtaining a copy of this software and associated documentation files
+# (the "Software"), to deal in the Software without restriction,
+# including without limitation the rights to use, copy, modify, merge,
+# publish, distribute, sublicense, and/or sell copies of the Software,
+# and to permit persons to whom the Software is furnished to do so,
+# subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be
+# included in all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
+# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
+# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+!ifndef KHIMAIRA_WIN32_CONFIG
+KHIMAIRA_WIN32_CONFIG=1
+
+# Environment Variables
+#  The following environment variables MUST be set:
+#   KH_ROOT : Root of the source tree.
+#   KH_BUILD: One of DEBUG or RETAIL
+#
+#  The following environment variables are optional:
+#   KH_RUNTIME: One of STATIC or DLL, specifies whether the CRT libs
+#               are linked statically or through MSVCRT.DLL.
+#   KH_AUXCFLAGS: Optional flags for CL
+#   KH_RELEASE: Release type.  One of OFFICIAL, PRERELEASE, PRIVATE or SPECIAL.
+#      OFFICIAL   : An official release of Khimaira
+#      PREPRELEASE: A beta/release candidate release
+#      PRIVATE    : Private build
+#      SPECIAL    : Special build.  Typically one with non-mainline patches.
+
+# Version info
+NETIDMGR_VERSION_MAJOR=1
+NETIDMGR_VERSION_MINOR=3
+NETIDMGR_VERSION_PATCH=1
+NETIDMGR_VERSION_AUX=0
+NETIDMGR_RELEASEDESC=
+
+# The API version.  This number must be incremented each time the API
+# changes.  Plugins specify the version of the API that they were
+# compiled against and the Module Manager uses the API numbers to
+# decide whether the plugin is safe to load or not.
+#
+# Changes to the API version numbers should be documented in
+# apiversion.txt at the root of the source tree.
+NETIDMGR_VERSION_API=10
+
+# Minimum backwards compatible version.  API versions from
+# NETIDMGR_VERSION_API_MINCOMPAT through NETIDMGR_VERSION_API
+# inclusive, are compatible with this version.
+NETIDMGR_VERSION_API_MINCOMPAT=5
+
+NETIDMGR_VERSION=$(NETIDMGR_VERSION_MAJOR).$(NETIDMGR_VERSION_MINOR).$(NETIDMGR_VERSION_PATCH).$(NETIDMGR_VERSION_AUX)
+NETIDMGR_VERSIONC=$(NETIDMGR_VERSION_MAJOR),$(NETIDMGR_VERSION_MINOR),$(NETIDMGR_VERSION_PATCH),$(NETIDMGR_VERSION_AUX)
+
+# Source information
+NETIDMGR_SRC_COMPANY_1033=Massachusetts Institute of Technology
+NETIDMGR_SRC_COPYRIGHT_1033=(C) 2005-2007 Massachusetts Institute of Technology
+
+# Choose the default build type if one is not set
+!if ("$(KH_BUILD)" != "DEBUG") && ("$(KH_BUILD)" != "RETAIL")
+!  if defined(NODEBUG) && "$(NODEBUG)"=="1"
+KH_BUILD=RETAIL
+!  else
+KH_BUILD=DEBUG
+!  endif
+!endif
+
+!if "$(KH_BUILD)"=="DEBUG" && defined(NODEBUG) && "$(NODEBUG)"=="1"
+! error The Khimaira build configuration is set for DEBUG while the Platform SDK build environment is set to RETAIL.
+!endif
+
+# The default release type is PRIVATE is no other type is specified
+!if ("$(KH_RELEASE)" != "OFFICIAL") && ("$(KH_RELEASE)" != "PRERELEASE") && ("$(KH_RELEASE)" != "PRIVATE") && ("$(KH_RELEASE)" != "SPECIAL")
+KH_RELEASE=PRIVATE
+!endif
+
+# Actual build environment settings
+
+# See what compiler we are using
+# TODO: Update this to support other compilers
+!if defined(MSVCVer) && "$(MSVCVer)"=="8.0"
+KH_CLVER=vc8
+!else
+KH_CLVER=vc7
+!endif
+
+# Check for required env vars
+!ifndef MODULE
+!      error MODULE must be specified
+!endif
+!ifndef KH_ROOT
+! ifndef PISMERE
+!   error Either KH_ROOT or PISMERE must be defined
+! else
+KH_ROOT=$(PISMERE)\athena\auth\krb5\src\windows\identity
+! endif
+!endif
+
+!ifdef NODEBUG
+OUTPRE_DBG=rel
+!else
+OUTPRE_DBG=dbg
+!endif
+OUTPRE1=obj
+OUTPRE2=$(OUTPRE1)\$(CPU)
+OUTPRE3=$(OUTPRE2)\$(OUTPRE_DBG)
+OUTPRE=$(OUTPRE3)^\
+
+
+
+# Output directory structure
+DESTROOT=$(KH_ROOT)\obj
+OBJROOT=$(KH_ROOT)\obj
+SRC=$(KH_ROOT)
+
+DESTDIR=$(DESTROOT)\$(CPU)\$(OUTPRE_DBG)
+OBJDIR=$(OBJROOT)\$(CPU)\$(OUTPRE_DBG)
+
+OBJ=$(OBJDIR)\$(MODULE)
+INCDIR=$(DESTDIR)\inc
+#BINDIR=$(DESTDIR)\bin
+BINDIR=$(KH_ROOT)\$(OUTPRE)\W2K
+#LIBDIR=$(DESTDIR)\lib
+LIBDIR=$(KH_ROOT)\$(OUTPRE)\W2K
+DOCDIR=$(DESTDIR)\doc
+
+# Source directories
+CONFDIR=$(SRC)\config
+
+# Setup environment for win32.mak
+
+!if "$(KH_BUILD)" == "RETAIL"
+NODEBUG=1
+!endif
+
+# Win32.mak
+APPVER=5.0
+TARGETOS=WINNT
+_WIN32_IE=0x0500
+_WIN32_WINNT=0x0500
+!include <Win32.Mak>
+
+# Program macros
+
+CD=cd
+RM=del /q
+MKDIR=mkdir
+RMDIR=rmdir
+ECHO=echo
+MAKECMD=nmake /nologo
+CP=copy /y
+LINK=link
+CCSV=perl $(SRC)\config\ccsv.pl
+MC=mc
+
+!ifdef KH_DOXYFULLPATH
+DOXYGEN=$(KH_DOXYFULLPATH)
+!else
+DOXYGEN=doxygen
+!endif
+
+!ifdef KH_HHCFULLPATH
+HHC=$(KH_HHCFULLPATH)
+!else
+HHC=hhc
+!endif
+
+!ifdef KH_KFWPATH
+KFWINCDIR=$(KH_KFWPATH)\inc
+kfwincflags = -I$(KFWINCDIR)\krb5 -I$(KFWINCDIR)\krb5\KerberosIV -I$(KFWINCDIR)\krb4 -I$(KFWINCDIR)\loadfuncs -I$(KFWINCDIR)
+KFWLIBDIR=$(KH_KFWPATH)\lib\$(CPU)
+!else if defined(PISMERE)
+KFWINCDIR=$(PISMERE)\athena\auth\krb5\src\include
+kfwincflags = -I$(KFWINCDIR) -I$(PISMERE)\athena\util\loadfuncs -I$(PISMERE)\athena\auth\krb5\src\include\kerberosIV -I$(PISMERE)\athena\auth\krb4\include
+KFWLIBDIR=$(PISMERE)\target\lib\$(CPU)\$(OUTPRE_DBG)
+!endif
+
+!ifdef KH_AFSPATH
+AFSINCDIR=$(KH_AFSPATH)\include
+AFSLIBDIR=$(KH_AFSPATH)\lib
+afsincflags=-I$(AFSINCDIR)
+!endif
+
+#EXTLIBDIR=$(SRC)\ext-lib\$(CPU)
+#EXTINCDIR=-I$(SRC)\ext-inc
+
+incflags= -I$(INCDIR) -I$(SRC)\include -I. -I$(OBJ) $(kfwincflags) $(afsincflags)
+rincflags= /i $(INCDIR) /i $(SRC)\include /i .
+khdefines=-DUNICODE -D_UNICODE
+khcwarn=/Wp64
+!ifndef KH_NO_WX
+khcwarn=$(khcwarn) /WX
+!endif
+
+!if "$(CPU)" == "i386"
+khdefines=$(khdefines) -D_USE_32BIT_TIME_T
+!endif
+
+#DEBUG_SYMBOLS
+ldebug=$(ldebug) /DEBUG
+cdebug=$(cdebug) -Os -Zi
+
+# Additionally, suppress conflicting default library directives that we
+# might pull in from external libraries.
+
+!ifndef NODEBUG
+lndeflibflag=/NODEFAULTLIB:MSVCRT
+!else
+lndeflibflag=/NODEFAULTLIB:MSVCRTD
+!endif
+
+khcflags=$(cdebug) $(cflags) $(incflags) $(khdefines) $(khcwarn)
+khlguiflags=$(ldebug) $(guilflags) $(lndeflibflag)
+khlconflags=$(ldebug) $(conlflags) $(lndeflibflag)
+khldllguiflags=$(ldebug) $(dlllflags) $(lndeflibflag)
+khldllconflags=$(ldebug) $(dlllflags) $(lndeflibflag)
+
+!if "$(KH_RUNTIME)" == "STATIC"
+khcflags=$(khcflags) $(cvarsmt)
+khlguiflags=$(khlguiflags) $(guilibsmt)
+khlconflags=$(khlconflags) $(conlibsmt)
+khldllguiflags=$(khldllguiflags) $(guilibsmt)
+khldllconflags=$(khldllconflags) $(conlibsmt)
+!else
+khcflags=$(khcflags) $(cvarsdll)
+khlguiflags=$(khlguiflags) $(guilibsdll)
+khlconflags=$(khlconflags) $(conlibsdll)
+khldllguiflags=$(khldllguiflags) $(guilibsdll)
+khldllconflags=$(khldllconflags) $(conlibsdll)
+!endif
+
+C2OBJ=$(CC) $(khcflags) $(KH_AUXCFLAGS) /Fo"$@" /c $**
+
+EXECONLINK=$(LINK) /NOLOGO $(khlconflags) /OUT:$@ $**
+
+EXEGUILINK=$(LINK) /NOLOGO $(khlguiflags) /OUT:$@ $**
+
+DLLCONLINK=$(LINK) /NOLOGO $(khldllconflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**
+
+DLLGUILINK=$(LINK) /NOLOGO $(khldllguiflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**
+
+DLLRESLINK=$(LINK) /NOLOGO /DLL /NOENTRY /MACHINE:$(PROCESSOR_ARCHITECTURE) /OUT:$@ $**
+
+RC2RES=$(RC) $(RFLAGS) $(rincflags) /fo $@ $**
+
+MC2RC=$(MC) $(MCFLAGS) -h $(OBJ)\ -m 1024 -r $(OBJ)\ -x $(OBJ)\ $**
+
+{}.c{$(OBJ)}.obj:
+       $(C2OBJ)
+
+{$(OBJ)}.c{$(OBJ)}.obj:
+       $(C2OBJ)
+
+{}.h{$(INCDIR)}.h:
+       $(CP) $** $@
+
+{}.rc{$(OBJ)}.res:
+       $(RC2RES)
+
+{$(OBJ)}.rc{$(OBJ)}.res:
+       $(RC2RES)
+
+clean::
+!if exist($(OBJ))
+       $(RM) $(OBJ)\
+!endif
+
+test::
+
+mkdirs::
+!if !exist($(LIBDIR))
+       $(MKDIR) $(LIBDIR)
+!endif
+!if !exist($(BINDIR))
+       $(MKDIR) $(BINDIR)
+!endif
+!if !exist($(OBJ))
+       $(MKDIR) $(OBJ)
+!endif
+
+TAGFILE = $(SRC)\TAGS
+
+etag::
+       etags -o $(TAGFILE) -a *.c *.h
+
+.SUFFIXES: .h
+
+!endif
index ffef7caa776c16bc2088c18226c851fad605f458..467a7d6e4057ec0915543475eb67cb079f6271f0 100644 (file)
-#\r
-#  Khimaira : Win32 configuration makefile\r
-#             This file will be included by all the makefiles\r
-#             in the build tree.\r
-#\r
-# Copyright (c) 2004,2005,2006 Massachusetts Institute of Technology\r
-# Copyright (c) 2006,2007 Secure Endpoints Inc.\r
-#\r
-# Permission is hereby granted, free of charge, to any person\r
-# obtaining a copy of this software and associated documentation files\r
-# (the "Software"), to deal in the Software without restriction,\r
-# including without limitation the rights to use, copy, modify, merge,\r
-# publish, distribute, sublicense, and/or sell copies of the Software,\r
-# and to permit persons to whom the Software is furnished to do so,\r
-# subject to the following conditions:\r
-#\r
-# The above copyright notice and this permission notice shall be\r
-# included in all copies or substantial portions of the Software.\r
-#\r
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,\r
-# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\r
-# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\r
-# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS\r
-# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\r
-# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
-# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\r
-# SOFTWARE.\r
-\r
-!ifndef KHIMAIRA_WIN32_CONFIG\r
-KHIMAIRA_WIN32_CONFIG=1\r
-\r
-# Environment Variables\r
-#  The following environment variables MUST be set:\r
-#   KH_ROOT : Root of the source tree.\r
-#   KH_BUILD: One of DEBUG or RETAIL\r
-#\r
-#  The following environment variables are optional:\r
-#   KH_RUNTIME: One of STATIC or DLL, specifies whether the CRT libs\r
-#               are linked statically or through MSVCRT.DLL.\r
-#   KH_AUXCFLAGS: Optional flags for CL\r
-#   KH_RELEASE: Release type.  One of OFFICIAL, PRERELEASE, PRIVATE or SPECIAL.\r
-#      OFFICIAL   : An official release of Khimaira\r
-#      PREPRELEASE: A beta/release candidate release\r
-#      PRIVATE    : Private build\r
-#      SPECIAL    : Special build.  Typically one with non-mainline patches.\r
-\r
-# Version info\r
-NETIDMGR_VERSION_MAJOR=1\r
-NETIDMGR_VERSION_MINOR=3\r
-NETIDMGR_VERSION_PATCH=0\r
-NETIDMGR_VERSION_AUX=0\r
-NETIDMGR_RELEASEDESC=\r
-\r
-# The API version.  This number must be incremented each time the API\r
-# changes.  Plugins specify the version of the API that they were\r
-# compiled against and the Module Manager uses the API numbers to\r
-# decide whether the plugin is safe to load or not.\r
-#\r
-# Changes to the API version numbers should be documented in\r
-# apiversion.txt at the root of the source tree.\r
-NETIDMGR_VERSION_API=9\r
-\r
-# Minimum backwards compatible version.  API versions from\r
-# NETIDMGR_VERSION_API_MINCOMPAT through NETIDMGR_VERSION_API\r
-# inclusive, are compatible with this version.\r
-NETIDMGR_VERSION_API_MINCOMPAT=5\r
-\r
-NETIDMGR_VERSION=$(NETIDMGR_VERSION_MAJOR).$(NETIDMGR_VERSION_MINOR).$(NETIDMGR_VERSION_PATCH).$(NETIDMGR_VERSION_AUX)\r
-NETIDMGR_VERSIONC=$(NETIDMGR_VERSION_MAJOR),$(NETIDMGR_VERSION_MINOR),$(NETIDMGR_VERSION_PATCH),$(NETIDMGR_VERSION_AUX)\r
-\r
-# Source information\r
-NETIDMGR_SRC_COMPANY_1033=Massachusetts Institute of Technology\r
-NETIDMGR_SRC_COPYRIGHT_1033=(C) 2005,2006 Massachusetts Institute of Technology\r
-\r
-# Choose the default build type if one is not set\r
-!if ("$(KH_BUILD)" != "DEBUG") && ("$(KH_BUILD)" != "RETAIL")\r
-!  if defined(NODEBUG) && "$(NODEBUG)"=="1"\r
-KH_BUILD=RETAIL\r
-!  else\r
-KH_BUILD=DEBUG\r
-!  endif\r
-!endif\r
-\r
-!if "$(KH_BUILD)"=="DEBUG" && defined(NODEBUG) && "$(NODEBUG)"=="1"\r
-! error The Khimaira build configuration is set for DEBUG while the Platform SDK build environment is set to RETAIL.\r
-!endif\r
-\r
-# The default release type is PRIVATE is no other type is specified\r
-!if ("$(KH_RELEASE)" != "OFFICIAL") && ("$(KH_RELEASE)" != "PRERELEASE") && ("$(KH_RELEASE)" != "PRIVATE") && ("$(KH_RELEASE)" != "SPECIAL")\r
-KH_RELEASE=PRIVATE\r
-!endif\r
-\r
-# Actual build environment settings\r
-\r
-# See what compiler we are using\r
-# TODO: Update this to support other compilers\r
-!if defined(MSVCVer) && "$(MSVCVer)"=="8.0"\r
-KH_CLVER=vc8\r
-!else\r
-KH_CLVER=vc7\r
-!endif\r
-\r
-# Check for required env vars\r
-!ifndef MODULE\r
-!      error MODULE must be specified\r
-!endif\r
-!ifndef KH_ROOT\r
-! ifndef PISMERE\r
-!   error Either KH_ROOT or PISMERE must be defined\r
-! else\r
-KH_ROOT=$(PISMERE)\athena\auth\krb5\src\windows\identity\r
-! endif\r
-!endif\r
-\r
-!ifdef NODEBUG\r
-OUTPRE_DBG=rel\r
-!else\r
-OUTPRE_DBG=dbg\r
-!endif\r
-OUTPRE1=obj\r
-OUTPRE2=$(OUTPRE1)\$(CPU)\r
-OUTPRE3=$(OUTPRE2)\$(OUTPRE_DBG)\r
-OUTPRE=$(OUTPRE3)^\\r
-\r
-\r
-\r
-# Output directory structure\r
-DESTROOT=$(KH_ROOT)\obj\r
-OBJROOT=$(KH_ROOT)\obj\r
-SRC=$(KH_ROOT)\r
-\r
-DESTDIR=$(DESTROOT)\$(CPU)\$(OUTPRE_DBG)\r
-OBJDIR=$(OBJROOT)\$(CPU)\$(OUTPRE_DBG)\r
-\r
-OBJ=$(OBJDIR)\$(MODULE)\r
-INCDIR=$(DESTDIR)\inc\r
-#BINDIR=$(DESTDIR)\bin\r
-BINDIR=$(KH_ROOT)\$(OUTPRE)\r
-#LIBDIR=$(DESTDIR)\lib\r
-LIBDIR=$(KH_ROOT)\$(OUTPRE)\r
-DOCDIR=$(DESTDIR)\doc\r
-\r
-# Source directories\r
-CONFDIR=$(SRC)\config\r
-\r
-# If we are forcing a Win2K build, we need to adjust the build\r
-# directories and environment.\r
-\r
-!ifdef KHBUILD_W2K\r
-\r
-OBJ=$(OBJ)\W2K\r
-BINDIR=$(BINDIR)\W2K\r
-LIBDIR=$(LIBDIR)\W2K\r
-\r
-APPVER=5.0\r
-TARGETOS=WINNT\r
-_WIN32_IE=0x0500\r
-_WIN32_WINNT=0x0500\r
-\r
-!endif\r
-\r
-# Setup environment for win32.mak\r
-\r
-!if "$(KH_BUILD)" == "RETAIL"\r
-NODEBUG=1\r
-!endif\r
-\r
-# Win32.mak\r
-\r
-!include <Win32.Mak>\r
-\r
-# Program macros\r
-\r
-CD=cd\r
-RM=del /q\r
-MKDIR=mkdir\r
-RMDIR=rmdir\r
-ECHO=echo\r
-MAKECMD=nmake /nologo\r
-CP=copy /y\r
-LINK=link\r
-CCSV=perl $(SRC)\config\ccsv.pl\r
-MC=mc\r
-\r
-!ifdef KH_DOXYFULLPATH\r
-DOXYGEN=$(KH_DOXYFULLPATH)\r
-!else\r
-DOXYGEN=doxygen\r
-!endif\r
-\r
-!ifdef KH_HHCFULLPATH\r
-HHC=$(KH_HHCFULLPATH)\r
-!else\r
-HHC=hhc\r
-!endif\r
-\r
-!ifdef KH_KFWPATH\r
-KFWINCDIR=$(KH_KFWPATH)\inc\r
-kfwincflags = -I$(KFWINCDIR)\krb5 -I$(KFWINCDIR)\krb5\KerberosIV -I$(KFWINCDIR)\krb4 -I$(KFWINCDIR)\loadfuncs -I$(KFWINCDIR)\r
-KFWLIBDIR=$(KH_KFWPATH)\lib\$(CPU)\r
-!else if defined(PISMERE)\r
-KFWINCDIR=$(PISMERE)\athena\auth\krb5\src\include\r
-kfwincflags = -I$(KFWINCDIR) -I$(PISMERE)\athena\util\loadfuncs -I$(PISMERE)\athena\auth\krb5\src\include\kerberosIV -I$(PISMERE)\athena\auth\krb4\include\r
-KFWLIBDIR=$(PISMERE)\target\lib\$(CPU)\$(OUTPRE_DBG)\r
-!endif\r
-\r
-!ifdef KH_AFSPATH\r
-AFSINCDIR=$(KH_AFSPATH)\include\r
-AFSLIBDIR=$(KH_AFSPATH)\lib\r
-afsincflags=-I$(AFSINCDIR)\r
-!endif\r
-\r
-#EXTLIBDIR=$(SRC)\ext-lib\$(CPU)\r
-#EXTINCDIR=-I$(SRC)\ext-inc\r
-\r
-incflags= -I$(INCDIR) -I$(SRC)\include -I. -I$(OBJ) $(kfwincflags) $(afsincflags)\r
-rincflags= /i $(INCDIR) /i $(SRC)\include /i .\r
-khdefines=-DUNICODE -D_UNICODE\r
-khcwarn=/Wp64\r
-!ifndef KH_NO_WX\r
-khcwarn=$(khcwarn) /WX\r
-!endif\r
-\r
-!if "$(CPU)" == "i386"\r
-khdefines=$(khdefines) -D_USE_32BIT_TIME_T\r
-!endif\r
-\r
-#DEBUG_SYMBOLS\r
-ldebug=$(ldebug) /DEBUG\r
-cdebug=$(cdebug) -Os -Zi\r
-\r
-# Additionally, suppress conflicting default library directives that we\r
-# might pull in from external libraries.\r
-\r
-!ifndef NODEBUG\r
-lndeflibflag=/NODEFAULTLIB:MSVCRT\r
-!else\r
-lndeflibflag=/NODEFAULTLIB:MSVCRTD\r
-!endif\r
-\r
-khcflags=$(cdebug) $(cflags) $(incflags) $(khdefines) $(khcwarn)\r
-khlguiflags=$(ldebug) $(guilflags) $(lndeflibflag)\r
-khlconflags=$(ldebug) $(conlflags) $(lndeflibflag)\r
-khldllguiflags=$(ldebug) $(dlllflags) $(lndeflibflag)\r
-khldllconflags=$(ldebug) $(dlllflags) $(lndeflibflag)\r
-\r
-!if "$(KH_RUNTIME)" == "STATIC"\r
-khcflags=$(khcflags) $(cvarsmt)\r
-khlguiflags=$(khlguiflags) $(guilibsmt)\r
-khlconflags=$(khlconflags) $(conlibsmt)\r
-khldllguiflags=$(khldllguiflags) $(guilibsmt)\r
-khldllconflags=$(khldllconflags) $(conlibsmt)\r
-!else\r
-khcflags=$(khcflags) $(cvarsdll)\r
-khlguiflags=$(khlguiflags) $(guilibsdll)\r
-khlconflags=$(khlconflags) $(conlibsdll)\r
-khldllguiflags=$(khldllguiflags) $(guilibsdll)\r
-khldllconflags=$(khldllconflags) $(conlibsdll)\r
-!endif\r
-\r
-C2OBJ=$(CC) $(khcflags) $(KH_AUXCFLAGS) /Fo"$@" /c $**\r
-\r
-EXECONLINK=$(LINK) /NOLOGO $(khlconflags) /OUT:$@ $**\r
-\r
-EXEGUILINK=$(LINK) /NOLOGO $(khlguiflags) /OUT:$@ $**\r
-\r
-DLLCONLINK=$(LINK) /NOLOGO $(khldllconflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**\r
-\r
-DLLGUILINK=$(LINK) /NOLOGO $(khldllguiflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**\r
-\r
-DLLRESLINK=$(LINK) /NOLOGO /DLL /NOENTRY /MACHINE:$(PROCESSOR_ARCHITECTURE) /OUT:$@ $**\r
-\r
-RC2RES=$(RC) $(RFLAGS) $(rincflags) /fo $@ $**\r
-\r
-MC2RC=$(MC) $(MCFLAGS) -h $(OBJ)\ -m 1024 -r $(OBJ)\ -x $(OBJ)\ $**\r
-\r
-{}.c{$(OBJ)}.obj:\r
-       $(C2OBJ)\r
-\r
-{$(OBJ)}.c{$(OBJ)}.obj:\r
-       $(C2OBJ)\r
-\r
-{}.h{$(INCDIR)}.h:\r
-       $(CP) $** $@\r
-\r
-{}.rc{$(OBJ)}.res:\r
-       $(RC2RES)\r
-\r
-{$(OBJ)}.rc{$(OBJ)}.res:\r
-       $(RC2RES)\r
-\r
-clean::\r
-!if exist($(OBJ))\r
-       $(RM) $(OBJ)\\r
-!endif\r
-\r
-test::\r
-\r
-mkdirs::\r
-!if !exist($(OBJ))\r
-       $(MKDIR) $(OBJ)\r
-!endif\r
-\r
-TAGFILE = $(SRC)\TAGS\r
-\r
-etag::\r
-       etags -o $(TAGFILE) -a *.c *.h\r
-\r
-.SUFFIXES: .h\r
-\r
-#\r
-# Manifest handling\r
-#\r
-# Starting with Visual Studio 8, the C compiler and the linker\r
-# generate manifests so that the applications will link with the\r
-# correct side-by-side DLLs at run-time.  These are required for\r
-# correct operation under Windows XP.  We also have custom manifests\r
-# which need to be merged with the manifests that VS creates.\r
-#\r
-# The syntax for invoking the _VC_MANIFEST_EMBED_foo macro is:\r
-# $(_VC_MANIFEST_EMBED_???) <any additional manifests that need to be merged in>\r
-#\r
-\r
-!ifndef MT\r
-MT=mt.exe -nologo\r
-!endif\r
-\r
-_VC_MANIFEST_EMBED_EXE= \\r
-if exist $@.manifest $(MT) -outputresource:$@;1 -manifest $@.manifest\r
-\r
-_VC_MANIFEST_EMBED_DLL= \\r
-if exist $@.manifest $(MT) -outputresource:$@;2 -manifest $@.manifest\r
-\r
-# Note that if you are merging manifests, then the VS generated\r
-# manifest should be cleaned up after calling _VC_MANIFEST_EMBED_???.\r
-# This ensures that even if the DLL or EXE is executed in-place, the\r
-# embedded manifest will be used.  Otherwise the $@.manifest file will\r
-# be used.\r
-_VC_MANIFEST_CLEAN= \\r
-if exist $@.manifest $(RM) $@.manifest\r
-\r
-# End of manifest handling\r
-\r
-!endif\r
+#
+#  Khimaira : Win32 configuration makefile
+#             This file will be included by all the makefiles
+#             in the build tree.
+#
+# Copyright (c) 2004,2005,2006 Massachusetts Institute of Technology
+# Copyright (c) 2006,2007 Secure Endpoints Inc.
+#
+# Permission is hereby granted, free of charge, to any person
+# obtaining a copy of this software and associated documentation files
+# (the "Software"), to deal in the Software without restriction,
+# including without limitation the rights to use, copy, modify, merge,
+# publish, distribute, sublicense, and/or sell copies of the Software,
+# and to permit persons to whom the Software is furnished to do so,
+# subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be
+# included in all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
+# BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
+# ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+# SOFTWARE.
+
+!ifndef KHIMAIRA_WIN32_CONFIG
+KHIMAIRA_WIN32_CONFIG=1
+
+# Environment Variables
+#  The following environment variables MUST be set:
+#   KH_ROOT : Root of the source tree.
+#   KH_BUILD: One of DEBUG or RETAIL
+#
+#  The following environment variables are optional:
+#   KH_RUNTIME: One of STATIC or DLL, specifies whether the CRT libs
+#               are linked statically or through MSVCRT.DLL.
+#   KH_AUXCFLAGS: Optional flags for CL
+#   KH_RELEASE: Release type.  One of OFFICIAL, PRERELEASE, PRIVATE or SPECIAL.
+#      OFFICIAL   : An official release of Khimaira
+#      PREPRELEASE: A beta/release candidate release
+#      PRIVATE    : Private build
+#      SPECIAL    : Special build.  Typically one with non-mainline patches.
+
+# Version info
+NETIDMGR_VERSION_MAJOR=1
+NETIDMGR_VERSION_MINOR=3
+NETIDMGR_VERSION_PATCH=1
+NETIDMGR_VERSION_AUX=0
+NETIDMGR_RELEASEDESC=
+
+# The API version.  This number must be incremented each time the API
+# changes.  Plugins specify the version of the API that they were
+# compiled against and the Module Manager uses the API numbers to
+# decide whether the plugin is safe to load or not.
+#
+# Changes to the API version numbers should be documented in
+# apiversion.txt at the root of the source tree.
+NETIDMGR_VERSION_API=10
+
+# Minimum backwards compatible version.  API versions from
+# NETIDMGR_VERSION_API_MINCOMPAT through NETIDMGR_VERSION_API
+# inclusive, are compatible with this version.
+NETIDMGR_VERSION_API_MINCOMPAT=5
+
+NETIDMGR_VERSION=$(NETIDMGR_VERSION_MAJOR).$(NETIDMGR_VERSION_MINOR).$(NETIDMGR_VERSION_PATCH).$(NETIDMGR_VERSION_AUX)
+NETIDMGR_VERSIONC=$(NETIDMGR_VERSION_MAJOR),$(NETIDMGR_VERSION_MINOR),$(NETIDMGR_VERSION_PATCH),$(NETIDMGR_VERSION_AUX)
+
+# Source information
+NETIDMGR_SRC_COMPANY_1033=Massachusetts Institute of Technology
+NETIDMGR_SRC_COPYRIGHT_1033=(C) 2005-2007 Massachusetts Institute of Technology
+
+# Choose the default build type if one is not set
+!if ("$(KH_BUILD)" != "DEBUG") && ("$(KH_BUILD)" != "RETAIL")
+!  if defined(NODEBUG) && "$(NODEBUG)"=="1"
+KH_BUILD=RETAIL
+!  else
+KH_BUILD=DEBUG
+!  endif
+!endif
+
+!if "$(KH_BUILD)"=="DEBUG" && defined(NODEBUG) && "$(NODEBUG)"=="1"
+! error The Khimaira build configuration is set for DEBUG while the Platform SDK build environment is set to RETAIL.
+!endif
+
+# The default release type is PRIVATE is no other type is specified
+!if ("$(KH_RELEASE)" != "OFFICIAL") && ("$(KH_RELEASE)" != "PRERELEASE") && ("$(KH_RELEASE)" != "PRIVATE") && ("$(KH_RELEASE)" != "SPECIAL")
+KH_RELEASE=PRIVATE
+!endif
+
+# Actual build environment settings
+
+# See what compiler we are using
+# TODO: Update this to support other compilers
+!if defined(MSVCVer) && "$(MSVCVer)"=="8.0"
+KH_CLVER=vc8
+!else
+KH_CLVER=vc7
+!endif
+
+# Check for required env vars
+!ifndef MODULE
+!      error MODULE must be specified
+!endif
+!ifndef KH_ROOT
+! ifndef PISMERE
+!   error Either KH_ROOT or PISMERE must be defined
+! else
+KH_ROOT=$(PISMERE)\athena\auth\krb5\src\windows\identity
+! endif
+!endif
+
+!ifdef NODEBUG
+OUTPRE_DBG=rel
+!else
+OUTPRE_DBG=dbg
+!endif
+OUTPRE1=obj
+OUTPRE2=$(OUTPRE1)\$(CPU)
+OUTPRE3=$(OUTPRE2)\$(OUTPRE_DBG)
+OUTPRE=$(OUTPRE3)^\
+
+
+
+# Output directory structure
+DESTROOT=$(KH_ROOT)\obj
+OBJROOT=$(KH_ROOT)\obj
+SRC=$(KH_ROOT)
+
+DESTDIR=$(DESTROOT)\$(CPU)\$(OUTPRE_DBG)
+OBJDIR=$(OBJROOT)\$(CPU)\$(OUTPRE_DBG)
+
+OBJ=$(OBJDIR)\$(MODULE)
+INCDIR=$(DESTDIR)\inc
+#BINDIR=$(DESTDIR)\bin
+BINDIR=$(KH_ROOT)\$(OUTPRE)
+#LIBDIR=$(DESTDIR)\lib
+LIBDIR=$(KH_ROOT)\$(OUTPRE)
+DOCDIR=$(DESTDIR)\doc
+
+# Source directories
+CONFDIR=$(SRC)\config
+
+# If we are forcing a Win2K build, we need to adjust the build
+# directories and environment.
+
+!ifdef KHBUILD_W2K
+
+OBJ=$(OBJ)\W2K
+BINDIR=$(BINDIR)\W2K
+LIBDIR=$(LIBDIR)\W2K
+
+APPVER=5.0
+TARGETOS=WINNT
+_WIN32_IE=0x0500
+_WIN32_WINNT=0x0500
+
+!endif
+
+# Setup environment for win32.mak
+
+!if "$(KH_BUILD)" == "RETAIL"
+NODEBUG=1
+!endif
+
+# Win32.mak
+
+!include <Win32.Mak>
+
+# Program macros
+
+CD=cd
+RM=del /q
+MKDIR=mkdir
+RMDIR=rmdir
+ECHO=echo
+MAKECMD=nmake /nologo
+CP=copy /y
+LINK=link
+CCSV=perl $(SRC)\config\ccsv.pl
+MC=mc
+
+!ifdef KH_DOXYFULLPATH
+DOXYGEN=$(KH_DOXYFULLPATH)
+!else
+DOXYGEN=doxygen
+!endif
+
+!ifdef KH_HHCFULLPATH
+HHC=$(KH_HHCFULLPATH)
+!else
+HHC=hhc
+!endif
+
+!ifdef KH_KFWPATH
+KFWINCDIR=$(KH_KFWPATH)\inc
+kfwincflags = -I$(KFWINCDIR)\krb5 -I$(KFWINCDIR)\krb5\KerberosIV -I$(KFWINCDIR)\krb4 -I$(KFWINCDIR)\loadfuncs -I$(KFWINCDIR)
+KFWLIBDIR=$(KH_KFWPATH)\lib\$(CPU)
+!else if defined(PISMERE)
+KFWINCDIR=$(PISMERE)\athena\auth\krb5\src\include
+kfwincflags = -I$(KFWINCDIR) -I$(PISMERE)\athena\util\loadfuncs -I$(PISMERE)\athena\auth\krb5\src\include\kerberosIV -I$(PISMERE)\athena\auth\krb4\include
+KFWLIBDIR=$(PISMERE)\target\lib\$(CPU)\$(OUTPRE_DBG)
+!endif
+
+!ifdef KH_AFSPATH
+AFSINCDIR=$(KH_AFSPATH)\include
+AFSLIBDIR=$(KH_AFSPATH)\lib
+afsincflags=-I$(AFSINCDIR)
+!endif
+
+#EXTLIBDIR=$(SRC)\ext-lib\$(CPU)
+#EXTINCDIR=-I$(SRC)\ext-inc
+
+incflags= -I$(INCDIR) -I$(SRC)\include -I. -I$(OBJ) $(kfwincflags) $(afsincflags)
+rincflags= /i $(INCDIR) /i $(SRC)\include /i .
+khdefines=-DUNICODE -D_UNICODE
+khcwarn=/Wp64
+!ifndef KH_NO_WX
+khcwarn=$(khcwarn) /WX
+!endif
+
+!if "$(CPU)" == "i386"
+khdefines=$(khdefines) -D_USE_32BIT_TIME_T
+!endif
+
+#DEBUG_SYMBOLS
+ldebug=$(ldebug) /DEBUG
+cdebug=$(cdebug) -Os -Zi
+
+# Additionally, suppress conflicting default library directives that we
+# might pull in from external libraries.
+
+!ifndef NODEBUG
+lndeflibflag=/NODEFAULTLIB:MSVCRT
+!else
+lndeflibflag=/NODEFAULTLIB:MSVCRTD
+!endif
+
+khcflags=$(cdebug) $(cflags) $(incflags) $(khdefines) $(khcwarn)
+khlguiflags=$(ldebug) $(guilflags) $(lndeflibflag)
+khlconflags=$(ldebug) $(conlflags) $(lndeflibflag)
+khldllguiflags=$(ldebug) $(dlllflags) $(lndeflibflag)
+khldllconflags=$(ldebug) $(dlllflags) $(lndeflibflag)
+
+!if "$(KH_RUNTIME)" == "STATIC"
+khcflags=$(khcflags) $(cvarsmt)
+khlguiflags=$(khlguiflags) $(guilibsmt)
+khlconflags=$(khlconflags) $(conlibsmt)
+khldllguiflags=$(khldllguiflags) $(guilibsmt)
+khldllconflags=$(khldllconflags) $(conlibsmt)
+!else
+khcflags=$(khcflags) $(cvarsdll)
+khlguiflags=$(khlguiflags) $(guilibsdll)
+khlconflags=$(khlconflags) $(conlibsdll)
+khldllguiflags=$(khldllguiflags) $(guilibsdll)
+khldllconflags=$(khldllconflags) $(conlibsdll)
+!endif
+
+C2OBJ=$(CC) $(khcflags) $(KH_AUXCFLAGS) /Fo"$@" /c $**
+
+EXECONLINK=$(LINK) /NOLOGO $(khlconflags) /OUT:$@ $**
+
+EXEGUILINK=$(LINK) /NOLOGO $(khlguiflags) /OUT:$@ $**
+
+DLLCONLINK=$(LINK) /NOLOGO $(khldllconflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**
+
+DLLGUILINK=$(LINK) /NOLOGO $(khldllguiflags) /OUT:$@ /IMPLIB:$(LIBDIR)\$(@B).lib $**
+
+DLLRESLINK=$(LINK) /NOLOGO /DLL /NOENTRY /MACHINE:$(PROCESSOR_ARCHITECTURE) /OUT:$@ $**
+
+RC2RES=$(RC) $(RFLAGS) $(rincflags) /fo $@ $**
+
+MC2RC=$(MC) $(MCFLAGS) -h $(OBJ)\ -m 1024 -r $(OBJ)\ -x $(OBJ)\ $**
+
+{}.c{$(OBJ)}.obj:
+       $(C2OBJ)
+
+{$(OBJ)}.c{$(OBJ)}.obj:
+       $(C2OBJ)
+
+{}.h{$(INCDIR)}.h:
+       $(CP) $** $@
+
+{}.rc{$(OBJ)}.res:
+       $(RC2RES)
+
+{$(OBJ)}.rc{$(OBJ)}.res:
+       $(RC2RES)
+
+clean::
+!if exist($(OBJ))
+       $(RM) $(OBJ)\
+!endif
+
+test::
+
+mkdirs::
+!if !exist($(OBJ))
+       $(MKDIR) $(OBJ)
+!endif
+
+TAGFILE = $(SRC)\TAGS
+
+etag::
+       etags -o $(TAGFILE) -a *.c *.h
+
+.SUFFIXES: .h
+
+#
+# Manifest handling
+#
+# Starting with Visual Studio 8, the C compiler and the linker
+# generate manifests so that the applications will link with the
+# correct side-by-side DLLs at run-time.  These are required for
+# correct operation under Windows XP.  We also have custom manifests
+# which need to be merged with the manifests that VS creates.
+#
+# The syntax for invoking the _VC_MANIFEST_EMBED_foo macro is:
+# $(_VC_MANIFEST_EMBED_???) <any additional manifests that need to be merged in>
+#
+
+!ifndef MT
+MT=mt.exe -nologo
+!endif
+
+_VC_MANIFEST_EMBED_EXE= \
+if exist $@.manifest $(MT) -outputresource:$@;1 -manifest $@.manifest
+
+_VC_MANIFEST_EMBED_DLL= \
+if exist $@.manifest $(MT) -outputresource:$@;2 -manifest $@.manifest
+
+# Note that if you are merging manifests, then the VS generated
+# manifest should be cleaned up after calling _VC_MANIFEST_EMBED_???.
+# This ensures that even if the DLL or EXE is executed in-place, the
+# embedded manifest will be used.  Otherwise the $@.manifest file will
+# be used.
+_VC_MANIFEST_CLEAN= \
+if exist $@.manifest $(RM) $@.manifest
+
+# End of manifest handling
+
+!endif