2 # target: windows nt/95
3 # Makefile for the Netwide Assembler
5 # The Netwide Assembler is copyright (C) 1996 Simon Tatham and
6 # Julian Hall. All rights reserved. The software is
7 # redistributable under the licence given in the file "Licence"
8 # distributed in the NASM archive.
10 # makefile designed for lcc-win32
11 # lcc-win32 is lcc (c compiler coded by guys from princeton uni)
12 # ported to win32 by jacob navia
13 # available at http://www.remcomp.com/lcc-win32/
16 CC = lcc.exe $(CFLAGS)
17 LFLAGS = -subsystem console -s
18 LD = lcclnk.exe $(LFLAGS)
24 NASM = nasm.${OBJ} nasmlib.${OBJ} float.${OBJ} insnsa.${OBJ} assemble.${OBJ} labels.${OBJ} \
25 parser.${OBJ} outform.${OBJ} output/outbin.${OBJ} output/outaout.${OBJ} output/outcoff.${OBJ} output/outelf.${OBJ} \
26 output/outobj.${OBJ} output/outas86.${OBJ} output/outrdf.${OBJ} output/outdbg.${OBJ} output/outrdf2.${OBJ} \
27 output/outieee.${OBJ} preproc.${OBJ} listing.${OBJ} eval.${OBJ}
29 NDISASM = ndisasm.${OBJ} disasm.${OBJ} sync.${OBJ} nasmlib.${OBJ} insnsd.${OBJ}
33 # linker response files
34 # that may take long, too much spawning command.com :)
35 NASM.LNK: makefile.lcc
36 echo nasm.$(OBJ) > NASM.LNK
37 echo nasmlib.$(OBJ) >> NASM.LNK
38 echo eval.$(OBJ) >> NASM.LNK
39 echo float.$(OBJ) >> NASM.LNK
40 echo insnsa.$(OBJ) >> NASM.LNK
41 echo assemble.$(OBJ) >> NASM.LNK
42 echo labels.$(OBJ) >> NASM.LNK
43 echo listing.$(OBJ) >> NASM.LNK
44 echo parser.$(OBJ) >> NASM.LNK
45 echo preproc.$(OBJ) >> NASM.LNK
46 echo outform.$(OBJ) >> NASM.LNK
47 echo output/outbin.$(OBJ) >> NASM.LNK
48 echo output/outaout.$(OBJ) >> NASM.LNK
49 echo output/outcoff.$(OBJ) >> NASM.LNK
50 echo output/outelf.$(OBJ) >> NASM.LNK
51 echo output/outobj.$(OBJ) >> NASM.LNK
52 echo output/outas86.$(OBJ) >> NASM.LNK
53 echo output/outrdf.$(OBJ) >> NASM.LNK
54 echo output/outrdf2.$(OBJ) >> NASM.LNK
55 echo output/outieee.$(OBJ) >> NASM.LNK
56 echo output/outdbg.$(OBJ) >> NASM.LNK
58 NDISASM.LNK: makefile.lcc
59 echo ndisasm.$(OBJ) > NDISASM.LNK
60 echo disasm.$(OBJ) >> NDISASM.LNK
61 echo sync.$(OBJ) >> NDISASM.LNK
62 echo nasmlib.$(OBJ) >> NDISASM.LNK
63 echo insnsd.$(OBJ) >> NDISASM.LNK
65 nasm: $(NASM) nasm.lnk
66 $(LD) -o nasm.exe @nasm.lnk
68 ndisasm: $(NDISASM) ndisasm.lnk
69 $(LD) -o ndisasm.exe @ndisasm.lnk
71 # These source files are automagically generated from a single
72 # instruction-table file by a Perl script. They're distributed,
73 # though, so it isn't necessary to have Perl just to recompile NASM
74 # from the distribution.
76 insnsa.c insnsd.c insnsi.h insnsn.c: insns.dat insns.pl
77 perl insns.pl insns.dat
79 # These files contains all the standard macros that are derived from
81 version.h: version version.pl
82 perl version.pl h < version > version.h
84 version.mac: version version.pl
85 perl version.pl mac < version > version.mac
87 # This source file is generated from the standard macros file
88 # `standard.mac' by another Perl script. Again, it's part of the
89 # standard distribution.
91 macros.c: standard.mac macros.pl version.mac
92 perl macros.pl standard.mac version.mac
94 # These source files are generated from regs.dat by yet another
96 regs.c: regs.dat regs.pl
97 perl regs.pl c regs.dat > regs.c
98 regflags.c: regs.dat regs.pl
99 perl regs.pl fc regs.dat > regflags.c
100 regdis.c: regs.dat regs.pl
101 perl regs.pl dc regs.dat > regdis.c
102 regvals.c: regs.dat regs.pl
103 perl regs.pl vc regs.dat > regvals.c
104 regs.h: regs.dat regs.pl
105 perl regs.pl h regs.dat > regs.h
108 rm -f *.${OBJ} nasm.exe ndisasm.exe
110 #-- Magic hints to mkdep.pl --#
111 # @object-ending: ".${OBJ}"
112 # @path-separator: "/"
113 #-- Everything below is generated by mkdep.pl - do not edit --#
114 assemble.${OBJ}: assemble.c insns.h assemble.h regvals.c nasm.h regs.h \
115 insnsi.h nasmlib.h version.h
116 disasm.${OBJ}: disasm.c insns.h regs.c sync.h names.c nasm.h disasm.h regs.h \
117 insnsn.c insnsi.h version.h regdis.c
118 eval.${OBJ}: eval.c nasm.h regs.h labels.h insnsi.h nasmlib.h version.h \
120 float.${OBJ}: float.c nasm.h regs.h insnsi.h version.h
121 insnsa.${OBJ}: insnsa.c insns.h nasm.h regs.h insnsi.h version.h
122 insnsd.${OBJ}: insnsd.c insns.h nasm.h regs.h insnsi.h version.h
123 insnsn.${OBJ}: insnsn.c
124 labels.${OBJ}: labels.c nasm.h regs.h insnsi.h nasmlib.h version.h
125 listing.${OBJ}: listing.c listing.h nasm.h regs.h insnsi.h nasmlib.h \
127 macros.${OBJ}: macros.c
128 names.${OBJ}: names.c regs.c insnsn.c
129 nasm.${OBJ}: nasm.c listing.h preproc.h insns.h outform.h assemble.h \
130 parser.h nasm.h regs.h labels.h insnsi.h nasmlib.h version.h eval.h
131 nasmlib.${OBJ}: nasmlib.c regs.c names.c nasm.h regs.h insnsn.c insnsi.h \
133 ndisasm.${OBJ}: ndisasm.c insns.h sync.h nasm.h disasm.h regs.h insnsi.h \
135 outform.${OBJ}: outform.c outform.h nasm.h regs.h insnsi.h version.h
136 output/outaout.${OBJ}: output/outaout.c outform.h nasm.h regs.h insnsi.h \
138 output/outas86.${OBJ}: output/outas86.c outform.h nasm.h regs.h insnsi.h \
140 output/outbin.${OBJ}: output/outbin.c outform.h nasm.h regs.h insnsi.h \
142 output/outcoff.${OBJ}: output/outcoff.c outform.h nasm.h regs.h insnsi.h \
144 output/outdbg.${OBJ}: output/outdbg.c outform.h nasm.h regs.h insnsi.h \
146 output/outelf.${OBJ}: output/outelf.c outform.h nasm.h regs.h insnsi.h \
148 output/outieee.${OBJ}: output/outieee.c outform.h nasm.h regs.h insnsi.h \
150 output/outobj.${OBJ}: output/outobj.c outform.h nasm.h regs.h insnsi.h \
152 output/outrdf.${OBJ}: output/outrdf.c outform.h nasm.h regs.h insnsi.h \
154 output/outrdf2.${OBJ}: output/outrdf2.c outform.h nasm.h regs.h insnsi.h \
156 parser.${OBJ}: parser.c parser.h nasm.h regs.h insnsi.h regflags.c float.h \
158 preproc.${OBJ}: preproc.c nasm.h macros.c regs.h insnsi.h nasmlib.h \
160 regdis.${OBJ}: regdis.c
161 regflags.${OBJ}: regflags.c
163 regvals.${OBJ}: regvals.c
164 sync.${OBJ}: sync.c sync.h