summaryrefslogtreecommitdiff
path: root/Mkfiles/Makefile.lcc
blob: 8809ade7615836ae4d7ef3e5118a8dab1167a291 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
# host: windows nt/95
# target: windows nt/95
# Makefile for the Netwide Assembler
#
# 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.

# makefile designed for lcc-win32
# lcc-win32 is lcc (c compiler coded by guys from princeton uni)
# ported to win32 by jacob navia
# available at http://www.remcomp.com/lcc-win32/

CFLAGS = -c -O -g2
CC = lcc.exe $(CFLAGS)
LFLAGS = -subsystem console -s
LD = lcclnk.exe $(LFLAGS)
OBJ = obj

.c.${OBJ}:
        $(CC) -o $@ $*.c

NASM = nasm.${OBJ} nasmlib.${OBJ} float.${OBJ} insnsa.${OBJ} assemble.${OBJ} labels.${OBJ} \
       parser.${OBJ} outform.${OBJ} output/outbin.${OBJ} output/outaout.${OBJ} output/outcoff.${OBJ} \
       output/outelf32.${OBJ} output/outelf64.${OBJ} \
       output/outobj.${OBJ} output/outas86.${OBJ} output/outrdf.${OBJ} output/outdbg.${OBJ} output/outrdf2.${OBJ} \
       output/outieee.${OBJ} preproc.${OBJ} listing.${OBJ} eval.${OBJ}

NDISASM = ndisasm.${OBJ} disasm.${OBJ} sync.${OBJ} nasmlib.${OBJ} insnsd.${OBJ}

all: nasm ndisasm

# linker response files
# that may take long, too much spawning command.com :)
NASM.LNK: makefile.lcc
        echo nasm.$(OBJ) > NASM.LNK
        echo nasmlib.$(OBJ) >> NASM.LNK
        echo eval.$(OBJ) >> NASM.LNK
        echo float.$(OBJ) >> NASM.LNK
        echo insnsa.$(OBJ) >> NASM.LNK
        echo assemble.$(OBJ) >> NASM.LNK
        echo labels.$(OBJ) >> NASM.LNK
        echo listing.$(OBJ) >> NASM.LNK
        echo parser.$(OBJ) >> NASM.LNK
        echo preproc.$(OBJ) >> NASM.LNK
        echo outform.$(OBJ) >> NASM.LNK
        echo output/outbin.$(OBJ) >> NASM.LNK
        echo output/outaout.$(OBJ) >> NASM.LNK
        echo output/outcoff.$(OBJ) >> NASM.LNK
        echo output/outelf32.$(OBJ) >> NASM.LNK
        echo output/outelf64.$(OBJ) >> NASM.LNK
        echo output/outobj.$(OBJ) >> NASM.LNK
        echo output/outas86.$(OBJ) >> NASM.LNK
        echo output/outrdf.$(OBJ) >> NASM.LNK
        echo output/outrdf2.$(OBJ) >> NASM.LNK
        echo output/outieee.$(OBJ) >> NASM.LNK
        echo output/outdbg.$(OBJ) >> NASM.LNK

NDISASM.LNK: makefile.lcc
        echo ndisasm.$(OBJ) > NDISASM.LNK
        echo disasm.$(OBJ) >> NDISASM.LNK
        echo sync.$(OBJ) >> NDISASM.LNK
        echo nasmlib.$(OBJ) >> NDISASM.LNK
        echo insnsd.$(OBJ) >> NDISASM.LNK

nasm: $(NASM) nasm.lnk
        $(LD) -o nasm.exe @nasm.lnk

ndisasm: $(NDISASM) ndisasm.lnk
        $(LD) -o ndisasm.exe @ndisasm.lnk

# These source files are automagically generated from a single
# instruction-table file by a Perl script. They're distributed,
# though, so it isn't necessary to have Perl just to recompile NASM
# from the distribution.

insnsa.c insnsd.c insnsi.h insnsn.c: insns.dat insns.pl
	perl insns.pl insns.dat

# These files contains all the standard macros that are derived from
# the version number.
version.h: version version.pl
	perl version.pl h < version > version.h

version.mac: version version.pl
	perl version.pl mac < version > version.mac

# This source file is generated from the standard macros file
# `standard.mac' by another Perl script. Again, it's part of the
# standard distribution.

macros.c: standard.mac macros.pl version.mac
	perl macros.pl standard.mac version.mac

# These source files are generated from regs.dat by yet another
# perl script.
regs.c: regs.dat regs.pl
	perl regs.pl c regs.dat > regs.c
regflags.c: regs.dat regs.pl
	perl regs.pl fc regs.dat > regflags.c
regdis.c: regs.dat regs.pl
	perl regs.pl dc regs.dat > regdis.c
regvals.c: regs.dat regs.pl
	perl regs.pl vc regs.dat > regvals.c
regs.h: regs.dat regs.pl
	perl regs.pl h regs.dat > regs.h

clean:
        rm -f *.${OBJ} nasm.exe ndisasm.exe

#-- Magic hints to mkdep.pl --#
# @object-ending: ".${OBJ}"
# @path-separator: "/"
#-- Everything below is generated by mkdep.pl - do not edit --#
assemble.${OBJ}: assemble.c preproc.h insns.h pptok.h regs.h regflags.c \
 config.h version.h nasmlib.h nasm.h regvals.c assemble.h insnsi.h
crc64.${OBJ}: crc64.c
disasm.${OBJ}: disasm.c insns.h sync.h regdis.c regs.h config.h regs.c \
 version.h nasm.h insnsn.c names.c insnsi.h disasm.h
eval.${OBJ}: eval.c labels.h eval.h regs.h config.h version.h nasmlib.h \
 nasm.h insnsi.h
float.${OBJ}: float.c regs.h config.h version.h nasm.h insnsi.h
hashtbl.${OBJ}: hashtbl.c regs.h config.h version.h nasmlib.h hashtbl.h \
 nasm.h insnsi.h
insnsa.${OBJ}: insnsa.c insns.h regs.h config.h version.h nasm.h insnsi.h
insnsd.${OBJ}: insnsd.c insns.h regs.h config.h version.h nasm.h insnsi.h
insnsn.${OBJ}: insnsn.c
labels.${OBJ}: labels.c regs.h config.h version.h hashtbl.h nasmlib.h nasm.h \
 insnsi.h
listing.${OBJ}: listing.c regs.h config.h version.h nasmlib.h nasm.h \
 insnsi.h listing.h
macros.${OBJ}: macros.c
names.${OBJ}: names.c regs.c insnsn.c
nasm.${OBJ}: nasm.c labels.h preproc.h insns.h parser.h eval.h pptok.h \
 regs.h outform.h config.h version.h nasmlib.h nasm.h stdscan.h assemble.h \
 insnsi.h listing.h
nasmlib.${OBJ}: nasmlib.c insns.h regs.h config.h version.h nasmlib.h nasm.h \
 insnsi.h
ndisasm.${OBJ}: ndisasm.c insns.h sync.h regs.h config.h version.h nasmlib.h \
 nasm.h insnsi.h disasm.h
outform.${OBJ}: outform.c regs.h config.h outform.h version.h nasm.h \
 insnsi.h
output/outaout.${OBJ}: output/outaout.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h stdscan.h insnsi.h
output/outas86.${OBJ}: output/outas86.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h insnsi.h
output/outbin.${OBJ}: output/outbin.c labels.h eval.h regs.h outform.h \
 config.h version.h nasmlib.h nasm.h stdscan.h insnsi.h
output/outcoff.${OBJ}: output/outcoff.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h insnsi.h
output/outdbg.${OBJ}: output/outdbg.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h insnsi.h
output/outelf32.${OBJ}: output/outelf32.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h stdscan.h insnsi.h
output/outelf64.${OBJ}: output/outelf64.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h stdscan.h insnsi.h
output/outieee.${OBJ}: output/outieee.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h insnsi.h
output/outmacho.${OBJ}: output/outmacho.c compiler.h regs.h outform.h \
 config.h version.h nasmlib.h nasm.h insnsi.h
output/outobj.${OBJ}: output/outobj.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h stdscan.h insnsi.h
output/outrdf.${OBJ}: output/outrdf.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h insnsi.h
output/outrdf2.${OBJ}: output/outrdf2.c rdoff/rdoff.h regs.h outform.h \
 config.h version.h nasmlib.h nasm.h insnsi.h
parser.${OBJ}: parser.c insns.h parser.h float.h regs.h regflags.c config.h \
 version.h nasmlib.h nasm.h stdscan.h insnsi.h
pptok.${OBJ}: pptok.c preproc.h pptok.h nasmlib.h
preproc.${OBJ}: preproc.c preproc.h macros.c pptok.h regs.h config.h \
 version.h nasmlib.h nasm.h insnsi.h
regdis.${OBJ}: regdis.c
regflags.${OBJ}: regflags.c
regs.${OBJ}: regs.c
regvals.${OBJ}: regvals.c
stdscan.${OBJ}: stdscan.c insns.h regs.h config.h version.h nasmlib.h nasm.h \
 stdscan.h insnsi.h
sync.${OBJ}: sync.c sync.h
tokhash.${OBJ}: tokhash.c insns.h regs.h config.h version.h nasm.h insnsi.h