mirror of
https://github.com/netwide-assembler/nasm.git
synced 2024-11-21 03:14:19 +08:00
79 lines
2.6 KiB
Makefile
79 lines
2.6 KiB
Makefile
# Makefile for the Netwide Assembler under 16-bit DOS
|
|
#
|
|
# The Netwide Assembler is copyright (C) 1996 Simon Tatham and
|
|
# Julian Hall. All rights reserved. The software is
|
|
# redistributable under the licence given in the file "Licence"
|
|
# distributed in the NASM archive.
|
|
#
|
|
# This Makefile is designed to build NASM using a 16-bit DOS C
|
|
# compiler such as Microsoft C, provided you have a compatible MAKE.
|
|
# It's been tested with Microsoft C 5.x plus Borland Make. (Yes, I
|
|
# know it's silly, but...)
|
|
|
|
CC = cl /c /O /AL /Gt
|
|
QCL = qcl /c /AL /Gt
|
|
LINK = cl
|
|
LINKFLAGS =
|
|
LIBRARIES =
|
|
EXE = .exe#
|
|
OBJ = obj#
|
|
|
|
.c.$(OBJ):
|
|
$(CC) $*.c
|
|
|
|
NASMOBJS = nasm.$(OBJ) nasmlib.$(OBJ) float.$(OBJ) insnsa.$(OBJ) \
|
|
assemble.$(OBJ) labels.$(OBJ) parser.$(OBJ) outform.$(OBJ) \
|
|
outbin.$(OBJ) outaout.$(OBJ) outcoff.$(OBJ) outelf.$(OBJ) \
|
|
outobj.$(OBJ) outas86.$(OBJ) outrdf.$(OBJ) outdbg.$(OBJ) \
|
|
preproc.$(OBJ) listing.$(OBJ) eval.$(OBJ)
|
|
|
|
NDISASMOBJS = ndisasm.$(OBJ) disasm.$(OBJ) sync.$(OBJ) nasmlib.$(OBJ) \
|
|
insnsd.$(OBJ)
|
|
|
|
all : nasm$(EXE) ndisasm$(EXE)
|
|
|
|
# We have to have a horrible kludge here to get round the 128 character
|
|
# limit, as usual...
|
|
LINKOBJS = a*.obj e*.obj f*.obj insnsa.obj l*.obj na*.obj o*.obj p*.obj
|
|
nasm$(EXE): $(NASMOBJS)
|
|
cl /Fenasm.exe /F 4000 $(LINKOBJS)
|
|
|
|
ndisasm$(EXE): $(NDISASMOBJS)
|
|
cl /Fendisasm.exe $(NDISASMOBJS)
|
|
|
|
assemble.$(OBJ): assemble.c nasm.h assemble.h insns.h
|
|
disasm.$(OBJ): disasm.c nasm.h disasm.h sync.h insns.h names.c
|
|
eval.$(OBJ): eval.c eval.h nasm.h nasmlib.h
|
|
float.$(OBJ): float.c nasm.h
|
|
labels.$(OBJ): labels.c nasm.h nasmlib.h
|
|
listing.$(OBJ): listing.c nasm.h nasmlib.h listing.h
|
|
nasm.$(OBJ): nasm.c nasm.h nasmlib.h parser.h assemble.h labels.h \
|
|
listing.h outform.h
|
|
nasmlib.$(OBJ): nasmlib.c nasm.h nasmlib.h
|
|
ndisasm.$(OBJ): ndisasm.c nasm.h sync.h disasm.h
|
|
outas86.$(OBJ): outas86.c nasm.h nasmlib.h
|
|
outaout.$(OBJ): outaout.c nasm.h nasmlib.h
|
|
outbin.$(OBJ): outbin.c nasm.h nasmlib.h
|
|
outcoff.$(OBJ): outcoff.c nasm.h nasmlib.h
|
|
outdbg.$(OBJ): outdbg.c nasm.h nasmlib.h
|
|
outelf.$(OBJ): outelf.c nasm.h nasmlib.h
|
|
outobj.$(OBJ): outobj.c nasm.h nasmlib.h
|
|
outrdf.$(OBJ): outrdf.c nasm.h nasmlib.h
|
|
outform.$(OBJ): outform.c outform.h nasm.h
|
|
parser.$(OBJ): parser.c nasm.h nasmlib.h parser.h float.h names.c
|
|
preproc.$(OBJ): preproc.c macros.c preproc.h nasm.h nasmlib.h
|
|
sync.$(OBJ): sync.c sync.h
|
|
|
|
# Another grotty hack: QC is less likely to run out of memory than
|
|
# CL proper; and we don't need any optimisation in these modules
|
|
# since they're just data.
|
|
insnsa.$(OBJ): insnsa.c nasm.h insns.h
|
|
$(QCL) insnsa.c
|
|
insnsd.$(OBJ): insnsd.c nasm.h insns.h
|
|
$(QCL) insnsd.c
|
|
|
|
clean :
|
|
del *.obj
|
|
del nasm$(EXE)
|
|
del ndisasm$(EXE)
|