]>
git.proxmox.com Git - grub2.git/blob - genmk.rb
3 # Copyright (C) 2002,2003,2004,2005,2006,2007,2008,2009 Free Software Foundation, Inc.
5 # This genmk.rb is free software; the author
6 # gives unlimited permission to copy and/or distribute it,
7 # with or without modifications, as long as this notice is preserved.
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY, to the extent permitted by law; without
11 # even the implied warranty of MERCHANTABILITY or FITNESS FOR A
15 def collect_with_index
17 self.each_with_index
do |item
, index
|
18 ret
.push(yield(item
, index
))
26 self.gsub(/[^a-zA-Z0-9_@]/, '_')
30 self.sub(/\.[^\.]*$/, '') + '.' + str
34 self.sub(/\.[^\.]*$/, '').to_var
+ '.o'
39 def initialize(dir
, name
)
44 attr_reader
:dir, :name
49 exe
= @name.suffix('exec')
50 objs
= sources
.collect
do |src
|
51 raise "unknown source file `#{src}'" if /\.[cS]$/ !~ src
52 prefix
+ '-' + src
.to_obj
54 objs_str
= objs
.join(' ')
55 deps
= objs
.collect
{|obj
| obj
.suffix('d')}
56 deps_str
= deps
.join(' ')
59 clean-image-#{@name}.#{@rule_count}:
60 rm -f #{@name} #{exe} #{objs_str}
62 CLEAN_IMAGE_TARGETS += clean-image-#{@name}.#{@rule_count}
64 mostlyclean-image-#{@name}.#{@rule_count}:
67 MOSTLYCLEAN_IMAGE_TARGETS += mostlyclean-image-#{@name}.#{@rule_count}
69 ifneq ($(TARGET_APPLE_CC),1)
71 $(OBJCOPY) -O $(#{prefix}_FORMAT) --strip-unneeded -R .note -R .comment -R .note.gnu.build-id $< $@
73 ifneq (#{exe},kernel.exec)
74 #{@name}: #{exe} ./grub-macho2img
75 ./grub-macho2img $< $@
77 #{@name}: #{exe} ./grub-macho2img
78 ./grub-macho2img --bss $< $@
83 $(TARGET_CC) -o $@ $^ $(TARGET_LDFLAGS) $(#{prefix}_LDFLAGS)
85 " + objs
.collect_with_index
do |obj
, i
|
87 fake_obj
= File
.basename(src
).suffix('o')
89 flag
= if /\.c$/ =~ src
then 'CFLAGS' else 'ASFLAGS' end
90 extra_flags
= if /\.S$/ =~ src
then '-DASM_FILE=1' else '' end
91 dir
= File
.dirname(src
)
93 "#{obj}: #{src} $(#{src}_DEPENDENCIES)
94 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -MD -c -o $@ $<
102 # Use PModule instead Module, to avoid name conflicting.
104 def initialize(dir
, name
)
109 attr_reader
:dir, :name
112 prefix
= @name.to_var
114 objs
= sources
.collect
do |src
|
115 raise "unknown source file `#{src}'" if /\.[cS]$/ !~ src
116 prefix
+ '-' + src
.to_obj
118 objs_str
= objs
.join(' ')
119 deps
= objs
.collect
{|obj
| obj
.suffix('d')}
120 deps_str
= deps
.join(' ')
121 pre_obj
= 'pre-' + @name.suffix('o')
122 mod_src
= 'mod-' + @name.suffix('c')
123 mod_obj
= mod_src
.suffix('o')
124 defsym
= 'def-' + @name.suffix('lst')
125 undsym
= 'und-' + @name.suffix('lst')
126 mod_name
= File
.basename(@name, '.mod')
127 symbolic_name
= mod_name
.sub(/\.[^\.]*$/, '')
130 clean-module-#{@name}.#{@rule_count}:
131 rm -f #{@name} #{mod_obj} #{mod_src} #{pre_obj} #{objs_str} #{undsym}
133 CLEAN_MODULE_TARGETS += clean-module-#{@name}.#{@rule_count}
135 ifneq ($(#{prefix}_EXPORTS),no)
136 clean-module-#{@name}-symbol.#{@rule_count}:
139 CLEAN_MODULE_TARGETS += clean-module-#{@name}-symbol.#{@rule_count}
140 DEFSYMFILES += #{defsym}
142 mostlyclean-module-#{@name}.#{@rule_count}:
145 MOSTLYCLEAN_MODULE_TARGETS += mostlyclean-module-#{@name}.#{@rule_count}
146 UNDSYMFILES += #{undsym}
148 ifneq ($(TARGET_APPLE_CC),1)
149 #{@name}: #{pre_obj} #{mod_obj} $(TARGET_OBJ2ELF)
151 $(TARGET_CC) $(#{prefix}_LDFLAGS) $(TARGET_LDFLAGS) -Wl,-r,-d -o $@ #{pre_obj} #{mod_obj}
152 if test ! -z \"$(TARGET_OBJ2ELF)\"; then ./$(TARGET_OBJ2ELF) $@ || (rm -f $@; exit 1); fi
153 $(STRIP) --strip-unneeded -K grub_mod_init -K grub_mod_fini -K _grub_mod_init -K _grub_mod_fini -R .note -R .comment $@
155 #{@name}: #{pre_obj} #{mod_obj} $(TARGET_OBJ2ELF)
158 $(TARGET_CC) $(#{prefix}_LDFLAGS) $(TARGET_LDFLAGS) -Wl,-r,-d -o $@.bin #{pre_obj} #{mod_obj}
159 $(OBJCONV) -f$(TARGET_MODULE_FORMAT) -nr:_grub_mod_init:grub_mod_init -nr:_grub_mod_fini:grub_mod_fini -wd1106 -nu -nd $@.bin $@
163 #{pre_obj}: $(#{prefix}_DEPENDENCIES) #{objs_str}
165 $(TARGET_CC) $(#{prefix}_LDFLAGS) $(TARGET_LDFLAGS) -Wl,-r,-d -o $@ #{objs_str}
167 #{mod_obj}: #{mod_src}
168 $(TARGET_CC) $(TARGET_CPPFLAGS) $(TARGET_CFLAGS) $(#{prefix}_CFLAGS) -c -o $@ $<
170 #{mod_src}: $(builddir)/moddep.lst $(srcdir)/genmodsrc.sh
171 sh $(srcdir)/genmodsrc.sh '#{mod_name}' $< > $@ || (rm -f $@; exit 1)
173 ifneq ($(#{prefix}_EXPORTS),no)
174 ifneq ($(TARGET_APPLE_CC),1)
175 #{defsym}: #{pre_obj}
176 $(NM) -g --defined-only -P -p $< | sed 's/^\\([^ ]*\\).*/\\1 #{mod_name}/' > $@
178 #{defsym}: #{pre_obj}
179 $(NM) -g -P -p $< | grep -E '^[a-zA-Z0-9_]* [TDS]' | sed 's/^\\([^ ]*\\).*/\\1 #{mod_name}/' > $@
183 #{undsym}: #{pre_obj}
184 echo '#{mod_name}' > $@
185 $(NM) -u -P -p $< | cut -f1 -d' ' >> $@
187 " + objs
.collect_with_index
do |obj
, i
|
189 fake_obj
= File
.basename(src
).suffix('o')
190 extra_target
= obj
.sub(/\.[^\.]*$/, '') + '-extra'
191 command
= 'cmd-' + obj
.suffix('lst')
192 fs
= 'fs-' + obj
.suffix('lst')
193 partmap
= 'partmap-' + obj
.suffix('lst')
194 handler
= 'handler-' + obj
.suffix('lst')
195 terminal
= 'terminal-' + obj
.suffix('lst')
196 parttool
= 'parttool-' + obj
.suffix('lst')
197 video
= 'video-' + obj
.suffix('lst')
199 flag
= if /\.c$/ =~ src
then 'CFLAGS' else 'ASFLAGS' end
200 extra_flags
= if /\.S$/ =~ src
then '-DASM_FILE=1' else '' end
201 dir
= File
.dirname(src
)
203 "#{obj}: #{src} $(#{src}_DEPENDENCIES)
204 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -MD -c -o $@ $<
207 clean-module-#{extra_target}.#{@rule_count}:
208 rm -f #{command} #{fs} #{partmap} #{handler} #{parttool} #{video}
210 CLEAN_MODULE_TARGETS += clean-module-#{extra_target}.#{@rule_count}
212 COMMANDFILES += #{command}
214 PARTTOOLFILES += #{parttool}
215 PARTMAPFILES += #{partmap}
216 HANDLERFILES += #{handler}
217 TERMINALFILES += #{terminal}
218 VIDEOFILES += #{video}
220 #{command}: #{src} $(#{src}_DEPENDENCIES) gencmdlist.sh
222 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -E $< \
223 | sh $(srcdir)/gencmdlist.sh #{symbolic_name} > $@ || (rm -f $@; exit 1)
225 #{fs}: #{src} $(#{src}_DEPENDENCIES) genfslist.sh
227 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -E $< \
228 | sh $(srcdir)/genfslist.sh #{symbolic_name} > $@ || (rm -f $@; exit 1)
230 #{parttool}: #{src} $(#{src}_DEPENDENCIES) genparttoollist.sh
232 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -E $< \
233 | sh $(srcdir)/genparttoollist.sh #{symbolic_name} > $@ || (rm -f $@; exit 1)
235 #{partmap}: #{src} $(#{src}_DEPENDENCIES) genpartmaplist.sh
237 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -E $< \
238 | sh $(srcdir)/genpartmaplist.sh #{symbolic_name} > $@ || (rm -f $@; exit 1)
240 #{handler}: #{src} $(#{src}_DEPENDENCIES) genhandlerlist.sh
242 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -E $< \
243 | sh $(srcdir)/genhandlerlist.sh #{symbolic_name} > $@ || (rm -f $@; exit 1)
245 #{terminal}: #{src} $(#{src}_DEPENDENCIES) genterminallist.sh
247 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -E $< \
248 | sh $(srcdir)/genterminallist.sh #{symbolic_name} > $@ || (rm -f $@; exit 1)
250 #{video}: #{src} $(#{src}_DEPENDENCIES) genvideolist.sh
252 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -E $< \
253 | sh $(srcdir)/genvideolist.sh #{symbolic_name} > $@ || (rm -f $@; exit 1)
261 def initialize(dir
, name
)
267 prefix
= @name.to_var
268 print
"#{@name}: $(#{prefix}_DEPENDENCIES) $(#{prefix}_OBJECTS)
269 $(CC) -o $@ $(#{prefix}_OBJECTS) $(LDFLAGS) $(#{prefix}_LDFLAGS)
273 attr_reader
:dir, :name
276 prefix
= @name.to_var
278 objs
= sources
.collect
do |src
|
279 raise "unknown source file `#{src}'" if /\.[cS]$/ !~ src
280 prefix
+ '-' + src
.to_obj
282 objs_str
= objs
.join(' ');
283 deps
= objs
.collect
{|obj
| obj
.suffix('d')}
284 deps_str
= deps
.join(' ');
287 clean-utility-#{@name}.#{@rule_count}:
288 rm -f #{@name}$(EXEEXT) #{objs_str}
290 CLEAN_UTILITY_TARGETS += clean-utility-#{@name}.#{@rule_count}
292 mostlyclean-utility-#{@name}.#{@rule_count}:
295 MOSTLYCLEAN_UTILITY_TARGETS += mostlyclean-utility-#{@name}.#{@rule_count}
297 #{prefix}_OBJECTS += #{objs_str}
299 " + objs
.collect_with_index
do |obj
, i
|
301 fake_obj
= File
.basename(src
).suffix('o')
303 dir
= File
.dirname(src
)
305 "#{obj}: #{src} $(#{src}_DEPENDENCIES)
306 $(CC) -I#{dir} -I$(srcdir)/#{dir} $(CPPFLAGS) $(CFLAGS) -DGRUB_UTIL=1 $(#{prefix}_CFLAGS) -MD -c -o $@ $<
315 def initialize(dir
, name
)
319 attr_reader
:dir, :name
322 prefix
= @name.to_var
323 objs
= sources
.collect
do |src
|
324 raise "unknown source file `#{src}'" if /\.[cS]$/ !~ src
325 prefix
+ '-' + src
.to_obj
327 objs_str
= objs
.join(' ');
328 deps
= objs
.collect
{|obj
| obj
.suffix('d')}
329 deps_str
= deps
.join(' ');
331 "CLEANFILES += #{@name} #{objs_str}
332 MOSTLYCLEANFILES += #{deps_str}
334 #{@name}: $(#{prefix}_DEPENDENCIES) #{objs_str}
335 $(TARGET_CC) -o $@ #{objs_str} $(TARGET_LDFLAGS) $(#{prefix}_LDFLAGS)
337 " + objs
.collect_with_index
do |obj
, i
|
339 fake_obj
= File
.basename(src
).suffix('o')
341 flag
= if /\.c$/ =~ src
then 'CFLAGS' else 'ASFLAGS' end
342 extra_flags
= if /\.S$/ =~ src
then '-DASM_FILE=1' else '' end
343 dir
= File
.dirname(src
)
345 "#{obj}: #{src} $(#{src}_DEPENDENCIES)
346 $(TARGET_CC) -I#{dir} -I$(srcdir)/#{dir} $(TARGET_CPPFLAGS) #{extra_flags} $(TARGET_#{flag}) $(#{prefix}_#{flag}) -MD -c -o $@ $<
355 def initialize(dir
, name
)
359 attr_reader
:dir, :name
362 if sources
.length
!= 1
363 raise "only a single source file must be specified for a script"
367 raise "unknown source file `#{src}'"
370 "CLEANFILES += #{@name}
372 #{@name}: #{src} $(#{src}_DEPENDENCIES) config.status
373 ./config.status --file=#{name}:#{src}
374 sed -i -e 's,@pkglib_DATA@,$(pkglib_DATA),g' $@
389 print
"# Generated by genmk.rb, please don't edit!\n"
403 str
.gsub
!(/\\\n/, ' ')
405 if /^([a-zA-Z0-9_]+)\s*\+?=\s*(.*?)\s*$/ =~ str
408 if var
=~
/^([a-zA-Z0-9_]+)_([A-Z]+)$/
409 prefix
, type
= $1, $2
413 images
+= args
.split(/\s+/).collect
do |img
|
414 Image
.new(prefix
, img
)
418 pmodules
+= args
.split(/\s+/).collect
do |pmod
|
419 PModule
.new(prefix
, pmod
)
423 utils
+= args
.split(/\s+/).collect
do |util
|
424 Utility
.new(prefix
, util
)
428 programs
+= args
.split(/\s+/).collect
do |prog
|
429 Program
.new(prefix
, prog
)
433 scripts
+= args
.split(/\s+/).collect
do |script
|
434 Script
.new(prefix
, script
)
438 if img
= images
.detect() {|i
| i
.name
.to_var
== prefix
}
439 print img
.rule(args
.split(/\s+/))
440 elsif pmod
= pmodules
.detect() {|m
| m
.name
.to_var
== prefix
}
441 print pmod
.rule(args
.split(/\s+/))
442 elsif util
= utils
.detect() {|u
| u
.name
.to_var
== prefix
}
443 print util
.rule(args
.split(/\s+/))
444 elsif program
= programs
.detect() {|u
| u
.name
.to_var
== prefix
}
445 print program
.rule(args
.split(/\s+/))
446 elsif script
= scripts
.detect() {|s
| s
.name
.to_var
== prefix
}
447 print script
.rule(args
.split(/\s+/))
457 utils
.each
{|util
| util
.print_tail()}