#******************************************************************************
#  Makefile for the KBDBASE directory
#
#       SCCSID = @(#)makefile   6.4 91/06/21
#
#       IBM/Microsoft Confidential
#
#       Copyright (c) IBM Corporation 1987, 1989
#       Copyright (c) Microsoft Corporation 1987, 1989
#
#       All Rights Reserved
#
#******************************************************************************

#******************************************************************************
#  Dot directive definition area (usually just suffixes)
#******************************************************************************

.SUFFIXES:
.SUFFIXES: .asm .def .exe .lnk .lst .obj .sym .sys

#******************************************************************************
#  Environment Setup for the component(s).
#******************************************************************************

#
# Conditional Setup Area and User Defines Macros
#

#
# Compiler Location w/ includes, libs and tools
#

H=..\..\..\..\h
INC=..\..\..\..\inc
LIB=..\..\..\..\lib
TOOLSPATH=..\..\..\..\tools

AINC= -I. -I.. -I$(INC) -I..\..\..\dos\dosinc -I..\..\..\sesmgr

#
# Since the compiler/linker and other tools use environment
# variables ( INCLUDE, LIB, etc ) in order to get the location of files,
# the following line will check the environment for the LIFE of the
# makefile and will be specific to this set of instructions. All MAKEFILES
# are requested to use this format to insure that they are using the correct
# level of files and tools.
#

!if [set INCLUDE=$(H);$(INC)] || [set LIB=$(LIB)] || [set PATH=$(TOOLSPATH)]
!endif
#

#
# Compiler/tools Macros
#

ASM=   masm
LINK=  link

#
# Compiler and Linker Options
#

!ifndef smp
AFLAGS= -Mx -t
!else
AFLAGS= -Mx -t -DSMP
!endif


#******************************************************************************
# Set up Macros that will contain all the different dependencies for the
# executables and dlls etc. that are generated.
#******************************************************************************

OBJS=   kbdstra.obj kbdioct.obj kbdxlat.obj kbdsubs.obj \
        kbdvdm.obj  kbdscan.obj kbdmon.obj  kbdiocg.obj \
        kbdiocs.obj kbdswap.obj kbdioab.obj kbdstic.obj \
        kbdfilt.obj kbdmse.obj  kbdtime.obj kbdidc.obj \
        kbdin.obj  kbddata.obj

LSTS=   kbdstra.lst kbdioct.lst kbdxlat.lst kbdsubs.lst \
        kbdvdm.lst  kbdscan.lst kbdmon.lst  kbdiocg.lst \
        kbdiocs.lst kbdswap.lst kbdioab.lst kbdstic.lst \
        kbdfilt.lst kbdmse.lst  kbdtime.lst kbdidc.lst \
        kbdin.lst  kbddata.lst
#******************************************************************************
#   Setup the inference rules for compiling and assembling source code to
#   object code.
#******************************************************************************

.asm.obj:
        $(ASM) $(AFLAGS) $(CYR) $(LAT) $(AINC) $*.asm $*.obj;
.asm.lst:
        $(ASM) -l -c $(AFLAGS) $(CYR) $(LAT) $(AINC) $*.asm $*.obj;

#******************************************************************************
#   Target Information
#******************************************************************************
#
# This is a very important step. The following small amount of code MUST
# NOT be removed from the program. The following directive will do
# dependency checking every time this component is built UNLESS the
# following is performed:
#                    A specific tag is used -- ie. all
#
# This allows the developer as well as the B & I group to perform incremental
# build with a degree of accuracy that has not been used before.
# There are some instances where certain types of INCLUDE files must be
# created first. This type of format will allow the developer to require
# that file to be created first. In order to achive that, all that has to
# be done is to make the DEPEND.MAK tag have your required target. Below is
# an example:
#
#    depend.mak:   { your file(s) } dephold
#
# Please DON'T remove the following line
#


#******************************************************************************
# Should be the default tag for all general processing
#******************************************************************************

all:    kbdbase.sys

list:   $(LSTS)

#******************************************************************************
#   Specific Description Block Information
#******************************************************************************

# This section would only be for specific direction as to how to create
# unique elements that are necessary to the build process. This could
# be compiling or assembling, creation of DEF files and other unique
# files.
# If all compiler and assembly rules are the same, use an inference rule to
# perform the compilation.
#

kbdbase.sys: kbddi.lnk kbddi.def $(OBJS)
        $(LINK) @kbddi.lnk;
        mapsym kbdbase.map

#******************************************************************************
