OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [insight/] [tcl/] [win/] [makefile.bc] - Rev 578

Go to most recent revision | Compare with Previous | Blame | View Log

# Copyright (c) 1995-1996 Sun Microsystems, Inc.
# RCS: @(#) $Id: makefile.bc,v 1.1.1.1 2002-01-16 10:25:38 markom Exp $
#
# Borland C++ 4.5 makefile
#

#
# Project directories
#
# ROOT = top of source tree
# TMPDIR = location where .obj files should be stored during build
# TOOLS = location of compiler and other development tools
#

ROOT    = ..
TMPDIR  = .
TOOLS   = c:\bc45

# uncomment the following line to compile with symbols
#DEBUG=1

# uncomment one of the following lines to compile with TCL_MEM_DEBUG,
# TCL_COMPILE_DEBUG, or TCL_COMPILE_STATS
#DEBUGDEFINES   =TCL_MEM_DEBUG 
#DEBUGDEFINES   =TCL_MEM_DEBUG;TCL_COMPILE_DEBUG
#DEBUGDEFINES   =TCL_MEM_DEBUG;TCL_COMPILE_STATS
#DEBUGDEFINES   =TCL_MEM_DEBUG;TCL_COMPILE_DEBUG;TCL_COMPILE_STATS


######################################################################
# Do not modify below this line
######################################################################

STACKSIZE = 1f0001

VERSION = 80

TCLLIB          = tcl$(VERSION).lib
TCLDLL          = tcl$(VERSION).dll
TCL16DLL        = tcl16$(VERSION).dll
TCLSH           = tclsh$(VERSION).exe
TCLTEST         = tcltest.exe
DUMPEXTS        = dumpexts.exe
TCLPIPEDLL      = tclpip$(VERSION).dll
TCLREGDLL       = tclreg$(VERSION).dll
CAT16           = cat16.exe
CAT32           = cat32.exe

TCLSHOBJS = \
        $(TMPDIR)\tclAppInit.obj

TCLTESTOBJS = \
        $(TMPDIR)\tclTest.obj \
        $(TMPDIR)\tclTestObj.obj \
        $(TMPDIR)\tclWinTest.obj \
        $(TMPDIR)\testMain.obj

TCLOBJS = \
        $(TMPDIR)\panic.obj \
        $(TMPDIR)\regexp.obj \
        $(TMPDIR)\strftime.obj \
        $(TMPDIR)\tclAlloc.obj \
        $(TMPDIR)\tclAsync.obj \
        $(TMPDIR)\tclBasic.obj \
        $(TMPDIR)\tclBinary.obj \
        $(TMPDIR)\tclCkalloc.obj \
        $(TMPDIR)\tclClock.obj \
        $(TMPDIR)\tclCmdAH.obj \
        $(TMPDIR)\tclCmdIL.obj \
        $(TMPDIR)\tclCmdMZ.obj \
        $(TMPDIR)\tclCompExpr.obj \
        $(TMPDIR)\tclCompile.obj \
        $(TMPDIR)\tclDate.obj \
        $(TMPDIR)\tclEnv.obj \
        $(TMPDIR)\tclEvent.obj \
        $(TMPDIR)\tclExecute.obj \
        $(TMPDIR)\tclFCmd.obj \
        $(TMPDIR)\tclFileName.obj \
        $(TMPDIR)\tclGet.obj \
        $(TMPDIR)\tclHash.obj \
        $(TMPDIR)\tclHistory.obj \
        $(TMPDIR)\tclIndexObj.obj \
        $(TMPDIR)\tclInterp.obj \
        $(TMPDIR)\tclIO.obj \
        $(TMPDIR)\tclIOCmd.obj \
        $(TMPDIR)\tclIOSock.obj \
        $(TMPDIR)\tclIOUtil.obj \
        $(TMPDIR)\tclLink.obj \
        $(TMPDIR)\tclListObj.obj \
        $(TMPDIR)\tclLoad.obj \
        $(TMPDIR)\tclMain.obj \
        $(TMPDIR)\tclNamesp.obj \
        $(TMPDIR)\tclNotify.obj \
        $(TMPDIR)\tclObj.obj \
        $(TMPDIR)\tclParse.obj \
        $(TMPDIR)\tclPipe.obj \
        $(TMPDIR)\tclPkg.obj \
        $(TMPDIR)\tclPosixStr.obj \
        $(TMPDIR)\tclPreserve.obj \
        $(TMPDIR)\tclProc.obj \
        $(TMPDIR)\tclResolve.obj \
        $(TMPDIR)\tclStringObj.obj \
        $(TMPDIR)\tclTimer.obj \
        $(TMPDIR)\tclUtil.obj \
        $(TMPDIR)\tclVar.obj \
        $(TMPDIR)\tclWin32Dll.obj \
        $(TMPDIR)\tclWinChan.obj \
        $(TMPDIR)\tclWinError.obj \
        $(TMPDIR)\tclWinFCmd.obj \
        $(TMPDIR)\tclWinFile.obj \
        $(TMPDIR)\tclWinInit.obj \
        $(TMPDIR)\tclWinLoad.obj \
        $(TMPDIR)\tclWinMtherr.obj \
        $(TMPDIR)\tclWinNotify.obj \
        $(TMPDIR)\tclWinPipe.obj \
        $(TMPDIR)\tclWinSock.obj \
        $(TMPDIR)\tclWinTime.obj

cc32            = $(TOOLS)\bin\bcc32.exe
link32          = $(TOOLS)\bin\tlink32.exe
rc32            = $(TOOLS)\bin\brcc32.exe
implib          = $(TOOLS)\bin\implib.exe

cc16            = $(TOOLS)\bin\bcc.exe
link16          = $(TOOLS)\bin\tlink.exe
rc16            = $(TOOLS)\bin\brcc32.exe -31

CP              = copy
RM              = del

WINDIR          = $(ROOT)\win
GENERICDIR      = $(ROOT)\generic

INCLUDES        = $(TOOLS)\include;$(WINDIR);$(GENERICDIR)
LIBDIRS         = $(TOOLS)\lib;$(WINDIR)

CON_CFLAGS      = +cfgexe.cfg -WC
TEST_CFLAGS     = +cfgtest.cfg
DLL16_CFLAGS    = $(PROJECTCCFLAGS) -I$(INCLUDES) -D$(DEFINES) -WD -ml -c \
                        -3 -d -w
TCL_CFLAGS      = +cfgdll.cfg

CON_LFLAGS      = -Tpe -ap -c $(DEBUGLDFLAGS) $(TOOLS)\lib\c0x32
DLL_LFLAGS      = -Tpd -aa -c $(DEBUGLDFLAGS) $(TOOLS)\lib\c0d32
GUI_LFLAGS      = -Tpe -aa -c $(DEBUGLDFLAGS) $(TOOLS)\lib\c0w32
DLL16_LFLAGS    = -Twd -c -C -A=16 $(DEBUGLDFLAGS16) $(TOOLS)\lib\c0dl

DLL_LIBS        = import32 cw32mti
CON_LIBS        = $(TCLLIB) import32 cw32mti
DLL16_LIBS      = import cwl

!ifndef DEBUG

# these macros cause maximum optimization and no symbols
DEBUGLDFLAGS = 
DEBUGCCFLAGS = -v- -vi- -O2
DEBUGLDFLAGS16 = -Oc -Oi -Oa -Or
!else

# these macros enable debugging
DEBUGLDFLAGS = -v
DEBUGCCFLAGS = -k -Od -v
DEBUGLDFLAGS16 = 

!endif

DEFINES = MT;_RTLDLL;$(DEBUGDEFINES)
PROJECTCCFLAGS = $(DEBUGCCFLAGS) -w-par -w-stu


# 
# Global makefile settings
#

.AUTODEPEND
.CACHEAUTODEPEND

.suffixes:

#.path.c=$(ROOT)\win;$(ROOT)\generic;$(ROOT)\compat
#.path.obj=$(TMPDIR)
#.path.dll=$(ROOT)\win

#
# Targets
#

release:    $(TCLSH) dlls
all:        $(TCLSH) dlls $(CAT16) $(CAT32) 
tcltest:    $(TCLTEST) dlls $(CAT16) $(CAT32)
dlls:       $(TCL16DLL) $(TCLPIPEDLL) $(TCLREGDLL)

test:       tcltest
        $(TCLTEST) &&|
                cd ../tests
                source all
|


$(DUMPEXTS): cfgexe.cfg $(WINDIR)\winDumpExts.c
        $(cc32) $(CON_CFLAGS) $(WINDIR)\winDumpExts.c
        $(link32) $(CON_LFLAGS) \
                $(TMPDIR)\winDumpExts.obj,$@,,import32 cw32mti,,

$(TCLLIB): $(TCLDLL)
        $(implib) -c $@ $(TCLDLL)

$(TCLDLL): cfgdll.cfg $(TCLOBJS) $(TMPDIR)\tcl.def $(TMPDIR)\tcl.res
        $(link32) $(DLL_LFLAGS) @&&|
                $(TCLOBJS)
$@
-x
$(DLL_LIBS)
|, $(TMPDIR)\tcl.def, $(TMPDIR)\tcl.res


$(TCLSH): cfgexe.cfg $(TCLSHOBJS) $(TCLLIB) $(TMPDIR)\tclsh.res
        $(link32) -S:$(STACKSIZE) $(CON_LFLAGS) @&&|
                $(TCLSHOBJS)
$@
-x
$(CON_LIBS)
|, &&|
EXETYPE WINDOWS
CODE PRELOAD MOVEABLE DISCARDABLE
DATA PRELOAD MOVEABLE MULTIPLE
|, $(TMPDIR)\tclsh.res

$(TCLTEST): cfgtest.cfg $(TCLTESTOBJS) $(TCLLIB) $(TMPDIR)\tclsh.res
        $(link32) -S:$(STACKSIZE) $(CON_LFLAGS) @&&|
                $(TCLTESTOBJS)
$@
-x
$(CON_LIBS)
|, &&|
EXETYPE WINDOWS
CODE PRELOAD MOVEABLE DISCARDABLE
DATA PRELOAD MOVEABLE MULTIPLE
|, $(TMPDIR)\tclsh.res


$(TCL16DLL): tcl16.rc $(ROOT)\win\tclWin16.c
        $(cc16) @&&|
$(DLL16_CFLAGS) -n$(TMPDIR) 
| $(ROOT)\win\tclWin16.c
        $(rc16) @&&|
-i$(INCLUDES) -d__WIN32__;$(DEFINES) -fo$(TMPDIR)\tcl16.res
| tcl16.rc
        @copy >nul &&|
LIBRARY $&;dll
EXETYPE WINDOWS
CODE PRELOAD MOVEABLE DISCARDABLE
DATA PRELOAD MOVEABLE SINGLE
HEAPSIZE 1024
EXPORTS
        WEP @1 RESIDENTNAME
        UTPROC @2 
| $(TMPDIR)\tclWin16.def
        $(link16) $(DLL16_LFLAGS) @&&|
$(TMPDIR)\tclWin16.obj
$@
nul
$(DLL16_LIBS)
$(TMPDIR)\tclWin16.def
|
        $(TOOLS)\bin\rlink $(TMPDIR)\tcl16.res $@

$(TCLPIPEDLL): cfgexe.cfg stub16.c
        $(cc32) -c -tWC stub16.c
        $(link32) $(CON_LFLAGS) -L$(TOOLS)\lib \
                stub16.obj,$@,,import32 cw32,,

$(TCLREGDLL): extdll.cfg $(TMPDIR)\tclWinReg.obj
        $(link32) $(DLL_LFLAGS) @&&|
                $(TMPDIR)\tclWinReg.obj
$@
-x
$(DLL_LIBS) $(TCLLIB)
|,,

#
# Special test targets
#

$(CAT32): cat.c
        $(cc32) -c -Ox -tWC -ocat32.obj cat.c
        $(link32) $(CON_LFLAGS) -L$(TOOLS)\lib \
                cat32.obj,$@,,import32 cw32,,

$(CAT16): cat.c
        $(cc16) -W- -ml -Ox -c -ocat16.obj cat.c
        $(link16) -Tde -c -L$(TOOLS)\lib $(TOOLS)\lib\c0l.obj cat16.obj,cat16.exe,,cl.lib,,

#######################################################################
# Implicit Targets
#######################################################################


{$(WINDIR)}.c{$(TMPDIR)}.obj:
        @$(cc32) $(TCL_CFLAGS) {$< }

{$(GENERICDIR)}.c{$(TMPDIR)}.obj:
        @$(cc32) $(TCL_CFLAGS) {$< }

{$(ROOT)\compat}.c{$(TMPDIR)}.obj:
        @$(cc32) $(TCL_CFLAGS) {$< }

{$(WINDIR)}.rc{$(TMPDIR)}.res:
        $(rc32) -i$(INCLUDES) -fo$@ @&&|
-d__WIN32__;$(DEFINES) $<
|

#
# Special case object file targets
#

$(TMPDIR)\tclWinReg.obj : extdll.cfg $(ROOT)\win\tclWinReg.c
        $(cc32) +extdll.cfg -o$@ $(ROOT)\win\tclWinReg.c

$(TMPDIR)\tclAppInit.obj : cfgexe.cfg $(ROOT)\win\tclAppInit.c
        $(cc32) $(CON_CFLAGS) -o$@ $(ROOT)\win\tclAppInit.c

$(TMPDIR)\testMain.obj : cfgexe.cfg $(ROOT)\win\tclAppInit.c
        $(cc32) $(TEST_CFLAGS) -o$@ $(ROOT)\win\tclAppInit.c

$(TMPDIR)\tclWin16.obj : $(ROOT)\win\tclWin16.c
        $(cc16) $(DLL16_CFLAGS) -o$@ $(ROOT)\win\tclWin16.c

#
# Configuration file targets - these files are implicitly used by the compiler
#

cfgdll.cfg:
        @$(CP) &&|
                -n$(TMPDIR) -I$(INCLUDES) -c -WM
                -D$(DEFINES) -3 -d -w $(PROJECTCCFLAGS)
| cfgdll.cfg >NUL

extdll.cfg:
        @$(CP) &&|
                -n$(TMPDIR) -I$(INCLUDES) -c -WD
                -D_RTLDLL;$(DEBUGDEFINES) -3 -d -w $(PROJECTCCFLAGS)
| extdll.cfg >NUL

cfgexe.cfg:
        @$(CP) &&|
                -n$(TMPDIR) -I$(INCLUDES) -c -W
                -D$(DEFINES) -3 -d -w $(PROJECTCCFLAGS)
| cfgexe.cfg >NUL

cfgtest.cfg:
        @$(CP) &&|
                -n$(TMPDIR) -I$(INCLUDES) -c -W
                -D$(DEFINES);TCL_TEST -3 -d -w $(PROJECTCCFLAGS)
| cfgtest.cfg >NUL

cfgcln:
        -@$(RM) *.cfg


# The following rule automatically generates a tcl.def file containing
# an export entry for every public symbol in the tcl.dll library.

$(TMPDIR)\tcl.def: $(TCLOBJS) $(DUMPEXTS)
        $(DUMPEXTS) -o $(TMPDIR)\tcl.def $(TCLDLL) @&&|
                $(TCLOBJS)
|


# the following two rules are a hack to get around the fact that the
# 16-bit compiler doesn't handle long file names :-(

$(ROOT)\win\tclWinIn.h: $(ROOT)\win\tclWinInt.h
        $(CP) $(ROOT)\win\tclWinInt.h $(ROOT)\win\tclWinIn.h

$(ROOT)\win\tclWin16.c: $(ROOT)\win\tclWinIn.h

# remove all generated files

clean:
        -@$(RM) *.exe
        -@$(RM) *.lib
        -@$(RM) *.dll
        -@$(RM) $(TMPDIR)\*.res
        -@$(RM) $(TMPDIR)\*.def
        -@$(RM) $(TMPDIR)\*.obj
        -@$(RM) $(TMPDIR)\*.cfg
        -@$(RM) $(ROOT)\win\tclWinIn.h

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.