do_subst.awk revision 1.4.8.2 1 1.4.8.2 takemura # $NetBSD: do_subst.awk,v 1.4.8.2 2001/04/15 12:27:33 takemura Exp $
2 1.4.8.2 takemura #
3 1.4.8.2 takemura # Copyright (c) 1999, 2000 Christopher G. Demetriou. All rights reserved.
4 1.4.8.2 takemura #
5 1.4.8.2 takemura # Redistribution and use in source and binary forms, with or without
6 1.4.8.2 takemura # modification, are permitted provided that the following conditions
7 1.4.8.2 takemura # are met:
8 1.4.8.2 takemura # 1. Redistributions of source code must retain the above copyright
9 1.4.8.2 takemura # notice, this list of conditions and the following disclaimer.
10 1.4.8.2 takemura # 2. Redistributions in binary form must reproduce the above copyright
11 1.4.8.2 takemura # notice, this list of conditions and the following disclaimer in the
12 1.4.8.2 takemura # documentation and/or other materials provided with the distribution.
13 1.4.8.2 takemura # 3. All advertising materials mentioning features or use of this software
14 1.4.8.2 takemura # must display the following acknowledgement:
15 1.4.8.2 takemura # This product includes software developed by Christopher G. Demetriou
16 1.4.8.2 takemura # for the NetBSD Project.
17 1.4.8.2 takemura # 4. The name of the author may not be used to endorse or promote products
18 1.4.8.2 takemura # derived from this software without specific prior written permission
19 1.4.8.2 takemura #
20 1.4.8.2 takemura # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
21 1.4.8.2 takemura # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
22 1.4.8.2 takemura # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
23 1.4.8.2 takemura # IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
24 1.4.8.2 takemura # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 1.4.8.2 takemura # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 1.4.8.2 takemura # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 1.4.8.2 takemura # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 1.4.8.2 takemura # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
29 1.4.8.2 takemura # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 1.4.8.2 takemura
31 1.4.8.2 takemura function setup_md_files (arch, env, srclist) {
32 1.4.8.2 takemura srclist=""
33 1.4.8.2 takemura asm_tmpl="dspgen/asm_build." arch
34 1.4.8.2 takemura prop_tmpl="dspgen/property." arch
35 1.4.8.2 takemura
36 1.4.8.2 takemura sz = split(ENVIRON[env], a, "[ \t\n]+");
37 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
38 1.4.8.2 takemura if (a[i] == "") {
39 1.4.8.2 takemura continue
40 1.4.8.2 takemura }
41 1.4.8.2 takemura if (srclist != "") {
42 1.4.8.2 takemura srclist=srclist "\n"
43 1.4.8.2 takemura }
44 1.4.8.2 takemura srclist=srclist "# Begin Source File\n"
45 1.4.8.2 takemura srclist=srclist "\n"
46 1.4.8.2 takemura srclist=srclist "SOURCE=.\\" a[i] "\n"
47 1.4.8.2 takemura base = index (a[i], ".asm")
48 1.4.8.2 takemura if (base != 0) {
49 1.4.8.2 takemura basename = substr (a[i], 0, base - 1)
50 1.4.8.2 takemura while (getline < asm_tmpl > 0) {
51 1.4.8.2 takemura gsub ("%%% ASM_BASENAME %%%", basename)
52 1.4.8.2 takemura srclist=srclist $0 "\n"
53 1.4.8.2 takemura }
54 1.4.8.2 takemura close (asm_tmpl)
55 1.4.8.2 takemura } else {
56 1.4.8.2 takemura while (getline < prop_tmpl > 0)
57 1.4.8.2 takemura srclist=srclist $0 "\n"
58 1.4.8.2 takemura close (prop_tmpl)
59 1.4.8.2 takemura }
60 1.4.8.2 takemura srclist=srclist "# End Source File"
61 1.4.8.2 takemura }
62 1.4.8.2 takemura return srclist
63 1.4.8.2 takemura }
64 1.4.8.2 takemura
65 1.4.8.2 takemura BEGIN {
66 1.4.8.2 takemura NAME=ENVIRON["NAME"]
67 1.4.8.2 takemura
68 1.4.8.2 takemura SRCFILES=""
69 1.4.8.2 takemura sz = split(ENVIRON["SRCFILE_LIST"], a, "[ \t\n]+");
70 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
71 1.4.8.2 takemura if (a[i] == "") {
72 1.4.8.2 takemura continue
73 1.4.8.2 takemura }
74 1.4.8.2 takemura if (SRCFILES != "") {
75 1.4.8.2 takemura SRCFILES=SRCFILES "\n"
76 1.4.8.2 takemura }
77 1.4.8.2 takemura SRCFILES=SRCFILES "# Begin Source File\n"
78 1.4.8.2 takemura SRCFILES=SRCFILES "\n"
79 1.4.8.2 takemura SRCFILES=SRCFILES "SOURCE=.\\" a[i] "\n"
80 1.4.8.2 takemura SRCFILES=SRCFILES "# End Source File"
81 1.4.8.2 takemura }
82 1.4.8.2 takemura
83 1.4.8.2 takemura SRCFILES_ARM = setup_md_files("ARM", "SRCFILE_LIST_ARM", SRCFILES_ARM)
84 1.4.8.2 takemura SRCFILES_SH3 = setup_md_files("SH3", "SRCFILE_LIST_SH3", SRCFILES_SH3)
85 1.4.8.2 takemura SRCFILES_SH4 = setup_md_files("SH4", "SRCFILE_LIST_SH3", SRCFILES_SH3)
86 1.4.8.2 takemura SRCFILES_SH = setup_md_files("SH", "SRCFILE_LIST_SH3", SRCFILES_SH3)
87 1.4.8.2 takemura SRCFILES_MIPS = setup_md_files("MIPS", "SRCFILE_LIST_MIPS",
88 1.4.8.2 takemura SRCFILES_MIPS)
89 1.4.8.2 takemura
90 1.4.8.2 takemura CPPDEFS=""
91 1.4.8.2 takemura sz = split(ENVIRON["STD_CPPDEF_LIST"], a, "[ \t\n]+");
92 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
93 1.4.8.2 takemura if (a[i] == "") {
94 1.4.8.2 takemura continue
95 1.4.8.2 takemura }
96 1.4.8.2 takemura if (CPPDEFS != "") {
97 1.4.8.2 takemura CPPDEFS=CPPDEFS " "
98 1.4.8.2 takemura }
99 1.4.8.2 takemura a[i] = gensub("([^\\\\]|^)#", "\\1 ", "g", a[i])
100 1.4.8.2 takemura a[i] = gensub("\\\\#", "#", "g", a[i])
101 1.4.8.2 takemura CPPDEFS=CPPDEFS "/D " a[i]
102 1.4.8.2 takemura }
103 1.4.8.2 takemura sz = split(ENVIRON["CPPDEF_LIST"], a, "[ \t\n]+");
104 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
105 1.4.8.2 takemura if (a[i] == "") {
106 1.4.8.2 takemura continue
107 1.4.8.2 takemura }
108 1.4.8.2 takemura if (CPPDEFS != "") {
109 1.4.8.2 takemura CPPDEFS=CPPDEFS " "
110 1.4.8.2 takemura }
111 1.4.8.2 takemura a[i] = gensub("([^\\\\]|^)#", "\\1 ", "g", a[i])
112 1.4.8.2 takemura a[i] = gensub("\\\\#", "#", "g", a[i])
113 1.4.8.2 takemura CPPDEFS=CPPDEFS "/D " a[i]
114 1.4.8.2 takemura }
115 1.4.8.2 takemura
116 1.4.8.2 takemura INCDIRS=""
117 1.4.8.2 takemura sz = split(ENVIRON["STD_INCDIR_LIST"], a, "[ \t\n]+");
118 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
119 1.4.8.2 takemura if (a[i] == "") {
120 1.4.8.2 takemura continue
121 1.4.8.2 takemura }
122 1.4.8.2 takemura if (INCDIRS != "") {
123 1.4.8.2 takemura INCDIRS=INCDIRS " "
124 1.4.8.2 takemura }
125 1.4.8.2 takemura INCDIRS=INCDIRS "/I \"" a[i] "\""
126 1.4.8.2 takemura }
127 1.4.8.2 takemura sz = split(ENVIRON["INCDIR_LIST"], a, "[ \t\n]+");
128 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
129 1.4.8.2 takemura if (a[i] == "") {
130 1.4.8.2 takemura continue
131 1.4.8.2 takemura }
132 1.4.8.2 takemura if (INCDIRS != "") {
133 1.4.8.2 takemura INCDIRS=INCDIRS " "
134 1.4.8.2 takemura }
135 1.4.8.2 takemura INCDIRS=INCDIRS "/I \"" a[i] "\""
136 1.4.8.2 takemura }
137 1.4.8.2 takemura sz = split(ENVIRON["LIBDEP_LIST"], a, "[ \t\n]+");
138 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
139 1.4.8.2 takemura if (a[i] == "") {
140 1.4.8.2 takemura continue
141 1.4.8.2 takemura }
142 1.4.8.2 takemura if (INCDIRS != "") {
143 1.4.8.2 takemura INCDIRS=INCDIRS " "
144 1.4.8.2 takemura }
145 1.4.8.2 takemura INCDIRS=INCDIRS "/I \"..\\" a[i] "\""
146 1.4.8.2 takemura }
147 1.4.8.2 takemura
148 1.4.8.2 takemura LIBRARIES=""
149 1.4.8.2 takemura sz = split(ENVIRON["STD_LIBRARY_LIST"], a, "[ \t\n]+");
150 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
151 1.4.8.2 takemura if (a[i] == "") {
152 1.4.8.2 takemura continue
153 1.4.8.2 takemura }
154 1.4.8.2 takemura if (LIBRARIES != "") {
155 1.4.8.2 takemura LIBRARIES=LIBRARIES " "
156 1.4.8.2 takemura }
157 1.4.8.2 takemura LIBRARIES=LIBRARIES a[i] ".lib"
158 1.4.8.2 takemura }
159 1.4.8.2 takemura sz = split(ENVIRON["LIBRARY_LIST"], a, "[ \t\n]+");
160 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
161 1.4.8.2 takemura if (a[i] == "") {
162 1.4.8.2 takemura continue
163 1.4.8.2 takemura }
164 1.4.8.2 takemura if (LIBRARIES != "") {
165 1.4.8.2 takemura LIBRARIES=LIBRARIES " "
166 1.4.8.2 takemura }
167 1.4.8.2 takemura LIBRARIES=LIBRARIES a[i] ".lib"
168 1.4.8.2 takemura }
169 1.4.8.2 takemura sz = split(ENVIRON["LIBDEP_LIST"], a, "[ \t\n]+");
170 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
171 1.4.8.2 takemura if (a[i] == "") {
172 1.4.8.2 takemura continue
173 1.4.8.2 takemura }
174 1.4.8.2 takemura if (LIBRARIES != "") {
175 1.4.8.2 takemura LIBRARIES=LIBRARIES " "
176 1.4.8.2 takemura }
177 1.4.8.2 takemura LIBRARIES=LIBRARIES a[i] ".lib"
178 1.4.8.2 takemura }
179 1.4.8.2 takemura
180 1.4.8.2 takemura sz = split(ENVIRON["LIBDEP_LIST"], a, "[ \t\n]+");
181 1.4.8.2 takemura DEBUG_LIBPATH=""
182 1.4.8.2 takemura RELEASE_LIBPATH=""
183 1.4.8.2 takemura for (i = 1; i <= sz; i++) {
184 1.4.8.2 takemura if (a[i] == "") {
185 1.4.8.2 takemura continue
186 1.4.8.2 takemura }
187 1.4.8.2 takemura if (i > 1) {
188 1.4.8.2 takemura DEBUG_LIBPATH=DEBUG_LIBPATH " "
189 1.4.8.2 takemura RELEASE_LIBPATH=RELEASE_LIBPATH " "
190 1.4.8.2 takemura }
191 1.4.8.2 takemura DEBUG_LIBPATH=DEBUG_LIBPATH "/libpath:\"..\\" a[i] "\\WMIPSDbg\""
192 1.4.8.2 takemura RELEASE_LIBPATH=RELEASE_LIBPATH "/libpath:\"..\\" a[i] "\\WMIPSRel\""
193 1.4.8.2 takemura }
194 1.4.8.2 takemura }
195 1.4.8.2 takemura {
196 1.4.8.2 takemura gsub("%%% SRCFILES %%%", SRCFILES)
197 1.4.8.2 takemura gsub("%%% SRCFILES_ARM %%%", SRCFILES_ARM)
198 1.4.8.2 takemura gsub("%%% SRCFILES_SH3 %%%", SRCFILES_SH3)
199 1.4.8.2 takemura gsub("%%% SRCFILES_SH4 %%%", SRCFILES_SH4)
200 1.4.8.2 takemura gsub("%%% SRCFILES_SH %%%", SRCFILES_SH)
201 1.4.8.2 takemura gsub("%%% SRCFILES_MIPS %%%", SRCFILES_MIPS)
202 1.4.8.2 takemura gsub("%%% CPPDEFS %%%", CPPDEFS)
203 1.4.8.2 takemura gsub("%%% INCDIRS %%%", INCDIRS)
204 1.4.8.2 takemura gsub("%%% LIBRARIES %%%", LIBRARIES)
205 1.4.8.2 takemura gsub("%%% DEBUG_LIBPATH %%%", DEBUG_LIBPATH)
206 1.4.8.2 takemura gsub("%%% RELEASE_LIBPATH %%%", RELEASE_LIBPATH)
207 1.4.8.2 takemura gsub("%%% NAME %%%", NAME)
208 1.4.8.2 takemura print $0
209 1.4.8.2 takemura }
210