make build by default
This commit is contained in:
parent
297f0c2b6e
commit
911bd64013
5 changed files with 354 additions and 499 deletions
|
@ -848,4 +848,5 @@ AM_CONDITIONAL([COND_GRUB_MKFONT], [test x$enable_grub_mkfont = xyes])
|
|||
AM_CONDITIONAL([COND_HAVE_FONT_SOURCE], [test x$FONT_SOURCE != x])
|
||||
AM_CONDITIONAL([COND_GRUB_FSTEST], [test x$enable_grub_fstest = xyes])
|
||||
AM_CONDITIONAL([COND_GRUB_PE2ELF], [test x$TARGET_OBJ2ELF != x])
|
||||
AM_CONDITIONAL([COND_APPLE_CC], [test x$TARGET_APPLE_CC != x])
|
||||
AM_CONDITIONAL([COND_ENABLE_EFIEMU], [test x$enable_efiemu = xyes])
|
||||
|
|
350
gentpl.py
350
gentpl.py
|
@ -17,7 +17,6 @@ GROUPS["sparc64"] = [ "sparc64_ieee1275" ]
|
|||
GROUPS["powerpc"] = [ "powerpc_ieee1275" ]
|
||||
GROUPS["x86"] = GROUPS["i386"] + GROUPS["x86_64"]
|
||||
GROUPS["x86_efi"] = [ "i386_efi", "x86_64_efi" ]
|
||||
GROUPS["common"] = GRUB_PLATFORMS[:]
|
||||
GROUPS["nonemu"] = GRUB_PLATFORMS[:]
|
||||
GROUPS["nonemu"].remove("emu")
|
||||
|
||||
|
@ -75,100 +74,92 @@ def var_add(var, value):
|
|||
# Autogen constructs
|
||||
#
|
||||
|
||||
def if_tag(tag, closure):
|
||||
return "[+ IF " + tag + " +]" + closure() + "[+ ENDIF +]"
|
||||
def set_canonical_name_suffix(suffix): return "[+ % name `export cname=$(echo -n %s" + suffix + " | sed -e 's/[^0-9A-Za-z@_]/_/g')` +]"
|
||||
def cname(): return "[+ % name `echo $cname` +]"
|
||||
|
||||
def if_tag_defined(tag, closure):
|
||||
return "[+ IF " + tag + " defined +]" + closure() + "[+ ENDIF +]"
|
||||
|
||||
def for_tag(tag, closure):
|
||||
return "[+ FOR ." + tag + " +]" + closure() + "[+ ENDFOR +]"
|
||||
|
||||
def collect_values(tag, prefix=""):
|
||||
return for_tag(tag, lambda: prefix + "[+ ." + tag + " +] ")
|
||||
|
||||
def each_group(platform, suffix, closure):
|
||||
r = None
|
||||
for group in RMAP[platform]:
|
||||
if r == None:
|
||||
r = "[+ IF ." + group + suffix + " +]"
|
||||
else:
|
||||
r += "[+ ELIF ." + group + suffix + " +]"
|
||||
|
||||
r += closure(group)
|
||||
|
||||
if r:
|
||||
r += "[+ ELSE +]"
|
||||
r += closure(None)
|
||||
r += "[+ ENDIF +]"
|
||||
def rule(target, source, cmd):
|
||||
if cmd[0] == "\n":
|
||||
return "\n" + target + ": " + source + cmd.replace("\n", "\n\t") + "\n"
|
||||
else:
|
||||
r = closure(None)
|
||||
return "\n" + target + ": " + source + "\n\t" + cmd.replace("\n", "\n\t") + "\n"
|
||||
|
||||
def if_platform_tagged(platform, tag, closure, c2=None):
|
||||
r = ""
|
||||
r += "[+ IF " + tag + " defined +]"
|
||||
r += "[+ FOR " + tag + " +][+ CASE " + tag + " +]"
|
||||
for group in RMAP[platform]:
|
||||
r += "[+ = \"" + group + "\" +]" + closure()
|
||||
r += "[+ ESAC +][+ ENDFOR +]"
|
||||
|
||||
if c2 == None:
|
||||
r += "[+ ENDIF +]"
|
||||
return r
|
||||
|
||||
r += "[+ ELSE +]" + c2() + "[+ ENDIF +]"
|
||||
return r
|
||||
|
||||
def platform_values(platform, group_tag, default_tag):
|
||||
r = ""
|
||||
for group in RMAP[platform]:
|
||||
gtag = group + group_tag
|
||||
|
||||
if group == RMAP[platform][0]:
|
||||
r += "[+ IF " + gtag + " +]"
|
||||
else:
|
||||
r += "[+ ELIF " + gtag + " +]"
|
||||
|
||||
r += "[+ FOR " + gtag + " +][+ ." + gtag + " +] [+ ENDFOR +]"
|
||||
r += "[+ ELSE +][+ FOR " + default_tag + " +][+ ." + default_tag + " +] [+ ENDFOR +][+ ENDIF +]"
|
||||
return r
|
||||
|
||||
def under_conditional(x):
|
||||
return "[+ IF condition +]\nif [+ condition +]\n[+ ENDIF +]" + x + "[+ IF condition +]\nendif\n[+ ENDIF +]"
|
||||
|
||||
def each_platform(closure):
|
||||
r = ""
|
||||
r = "[+ IF - enable undefined +]"
|
||||
for platform in GRUB_PLATFORMS:
|
||||
for group in RMAP[platform]:
|
||||
if group == RMAP[platform][0]:
|
||||
r += "[+ IF ." + group + " defined +]"
|
||||
else:
|
||||
r += "[+ ELIF ." + group + " defined +]"
|
||||
r += "\nif COND_" + platform + "\n" + closure(platform) + "endif\n"
|
||||
r += "[+ ELSE +]"
|
||||
for platform in GRUB_PLATFORMS:
|
||||
x = "\nif COND_" + platform + "\n" + closure(platform) + "endif\n"
|
||||
r += if_platform_tagged(platform, "enable", lambda: x)
|
||||
r += "[+ ENDIF +]"
|
||||
return r;
|
||||
|
||||
r += "if COND_" + platform + "\n"
|
||||
r += closure(platform)
|
||||
r += "endif\n"
|
||||
r += "[+ ENDIF +]"
|
||||
return r
|
||||
def shared_sources(): return "[+ FOR shared +][+ .shared +] [+ ENDFOR +]"
|
||||
def shared_nodist_sources(): return "[+ FOR nodist_shared +] [+ .nodist_shared +][+ ENDFOR +]"
|
||||
|
||||
def canonical_name(): return "[+ % name `echo -n %s | sed -e 's/[^0-9A-Za-z@_]/_/g'` +]"
|
||||
def canonical_module(): return canonical_name() + "_module"
|
||||
def canonical_kernel(): return canonical_name() + "_img"
|
||||
def canonical_image(): return canonical_name() + "_image"
|
||||
def platform_sources(p): return platform_values(p, "", "source")
|
||||
def platform_nodist_sources(p): return platform_values(p, "_nodist", "nodist")
|
||||
def platform_extra_dist(p): return platform_values(p, "_extra_dist", "extra_dist")
|
||||
|
||||
def shared_sources(prefix=""): return collect_values("shared", prefix)
|
||||
def shared_nodist_sources(prefix=""): return collect_values("nodist_shared", prefix)
|
||||
|
||||
def default_sources(prefix=""): return collect_values("source", prefix)
|
||||
def default_nodist_sources(prefix=""): return collect_values("nodist", prefix)
|
||||
def default_ldadd(): return collect_values("ldadd")
|
||||
def default_cflags(): return collect_values("cflags")
|
||||
def default_ldflags(): return collect_values("ldflags")
|
||||
def default_cppflags(): return collect_values("cppflags")
|
||||
def default_ccasflags(): return collect_values("ccasflags")
|
||||
def default_extra_dist(): return collect_values("extra_dist")
|
||||
|
||||
def group_sources(group, prefix=""): return collect_values(group, prefix) if group else default_sources(prefix)
|
||||
def group_nodist_sources(group, prefix=""): return collect_values(group + "_nodist", prefix) if group else default_nodist_sources(prefix)
|
||||
|
||||
def platform_sources(platform, prefix=""): return each_group(platform, "", lambda g: collect_values(g, prefix) if g else default_sources(prefix))
|
||||
def platform_nodist_sources(platform, prefix=""): return each_group(platform, "_nodist", lambda g: collect_values(g + "_nodist", prefix) if g else default_nodist_sources(prefix))
|
||||
|
||||
def platform_ldadd(platform): return each_group(platform, "_ldadd", lambda g: collect_values(g + "_ldadd") if g else default_ldadd())
|
||||
def platform_cflags(platform): return each_group(platform, "_cflags", lambda g: collect_values(g + "_cflags") if g else default_cflags())
|
||||
def platform_ldflags(platform): return each_group(platform, "_ldflags", lambda g: collect_values(g + "_ldflags") if g else default_ldflags())
|
||||
def platform_cppflags(platform): return each_group(platform, "_cppflags", lambda g: collect_values(g + "_cppflags") if g else default_cppflags())
|
||||
def platform_ccasflags(platform): return each_group(platform, "_ccasflags", lambda g: collect_values(g + "_ccasflags") if g else default_ccasflags())
|
||||
def platform_extra_dist(platform): return each_group(platform, "_extra_dist", lambda g: collect_values(g + "_extra_dist") if g else default_extra_dist())
|
||||
def platform_format(platform): return each_group(platform, "_format", lambda g: collect_values(g + "_format") if g else "binary")
|
||||
def platform_ldadd(p): return platform_values(p, "_ldadd", "ldadd")
|
||||
def platform_cflags(p): return platform_values(p, "_cflags", "cflags")
|
||||
def platform_ldflags(p): return platform_values(p, "_ldflags", "ldflags")
|
||||
def platform_cppflags(p): return platform_values(p, "_cppflags", "cppflags")
|
||||
def platform_ccasflags(p): return platform_values(p, "_ccasflags", "ccasflags")
|
||||
def platform_stripflags(p): return platform_values(p, "_stripflags", "stripflags")
|
||||
def platform_objcopyflags(p): return platform_values(p, "_objcopyflags", "objcopyflags")
|
||||
|
||||
def module(platform):
|
||||
r = gvar_add("noinst_PROGRAMS", "[+ name +].module")
|
||||
r = set_canonical_name_suffix(".module")
|
||||
|
||||
r += gvar_add("noinst_PROGRAMS", "[+ name +].module")
|
||||
r += gvar_add("MODULE_FILES", "[+ name +].module$(EXEEXT)")
|
||||
|
||||
r += var_set(canonical_module() + "_SOURCES", platform_sources(platform) + "## platform sources")
|
||||
r += var_add(canonical_module() + "_SOURCES", shared_sources() + "## shared sources")
|
||||
r += var_set("nodist_" + canonical_module() + "_SOURCES", platform_nodist_sources(platform) + "## platform nodist sources")
|
||||
r += var_add("nodist_" + canonical_module() + "_SOURCES", shared_nodist_sources() + "## shared nodist sources")
|
||||
r += var_set(canonical_module() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(canonical_module() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_MODULE) " + platform_cflags(platform))
|
||||
r += var_set(canonical_module() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_MODULE) " + platform_ldflags(platform))
|
||||
r += var_set(canonical_module() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_MODULE) " + platform_cppflags(platform))
|
||||
r += var_set(canonical_module() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_MODULE) " + platform_ccasflags(platform))
|
||||
r += var_set(cname() + "_SOURCES", platform_sources(platform) + " ## platform sources")
|
||||
r += var_add(cname() + "_SOURCES", shared_sources() + " ## shared sources")
|
||||
r += var_set("nodist_" + cname() + "_SOURCES", platform_nodist_sources(platform) + " ## platform nodist sources")
|
||||
r += var_add("nodist_" + cname() + "_SOURCES", shared_nodist_sources() + " ## shared nodist sources")
|
||||
r += var_set(cname() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(cname() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_MODULE) " + platform_cflags(platform))
|
||||
r += var_set(cname() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_MODULE) " + platform_ldflags(platform))
|
||||
r += var_set(cname() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_MODULE) " + platform_cppflags(platform))
|
||||
r += var_set(cname() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_MODULE) " + platform_ccasflags(platform))
|
||||
|
||||
r += gvar_add("EXTRA_DIST", platform_extra_dist(platform))
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + canonical_module() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + canonical_module() + "_SOURCES)")
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
|
||||
r += gvar_add("DEF_FILES", "def-[+ name +].lst")
|
||||
r += gvar_add("UND_FILES", "und-[+ name +].lst")
|
||||
|
@ -189,8 +180,8 @@ def module(platform):
|
|||
|
||||
r += gvar_add("CLEANFILES", "[+ name +].pp")
|
||||
r += """
|
||||
[+ name +].pp: $(""" + canonical_module() + """_SOURCES) $(nodist_""" + canonical_module() + """_SOURCES)
|
||||
$(TARGET_CPP) -DGRUB_LST_GENERATOR $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(""" + canonical_module() + """_CPPFLAGS) $(CPPFLAGS) $^ > $@ || (rm -f $@; exit 1)
|
||||
[+ name +].pp: $(""" + cname() + """_SOURCES) $(nodist_""" + cname() + """_SOURCES)
|
||||
$(TARGET_CPP) -DGRUB_LST_GENERATOR $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(""" + cname() + """_CPPFLAGS) $(CPPFLAGS) $^ > $@ || (rm -f $@; exit 1)
|
||||
|
||||
def-[+ name +].lst: [+ name +].module$(EXEEXT)
|
||||
if test x$(USE_APPLE_CC_FIXES) = xyes; then \
|
||||
|
@ -242,64 +233,47 @@ terminal-[+ name +].lst: [+ name +].pp $(top_srcdir)/genterminallist.sh
|
|||
"""
|
||||
return r
|
||||
|
||||
def rule(target, source, cmd):
|
||||
if cmd[0] == "\n":
|
||||
return "\n" + target + ": " + source + cmd.replace("\n", "\n\t") + "\n"
|
||||
else:
|
||||
return "\n" + target + ": " + source + "\n\t" + cmd.replace("\n", "\n\t") + "\n"
|
||||
|
||||
def image_nostrip(platform):
|
||||
return if_tag_defined("image_nostrip." + platform, lambda: rule("[+ name +].img", "[+ name +].exec", "cp $< $@"))
|
||||
|
||||
def image_strip(platform):
|
||||
return if_tag_defined("image_strip." + platform, lambda: rule("[+ name +].img", "[+ name +].exec", "$(STRIP) -o $@ -R .rel.dyn -R .reginfo -R .note -R .comment $<"))
|
||||
|
||||
def image_strip_keep_kernel(platform):
|
||||
return if_tag_defined("image_strip_keep_kernel." + platform, lambda: rule("[+ name +].img", "[+ name +].exec", "$(STRIP) -o $@ --strip-unneeded -K start -R .note -R .comment $<"))
|
||||
|
||||
def image_strip_macho2img(platform):
|
||||
return if_tag_defined("image_strip_macho2img." + platform, lambda: rule("[+ name +].img", "[+ name +].exec", """
|
||||
if test "x$(TARGET_APPLE_CC)" = x1; then \
|
||||
$(MACHO2IMG) --bss $< $@ || exit 1; \
|
||||
else \
|
||||
$(STRIP) -o $@ -O binary --strip-unneeded -R .note -R .comment -R .note.gnu.build-id -R .reginfo -R .rel.dyn $< || exit 1; \
|
||||
fi
|
||||
"""))
|
||||
|
||||
def kernel(platform):
|
||||
r = gvar_add("noinst_PROGRAMS", "[+ name +].img")
|
||||
r += var_set(canonical_kernel() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(canonical_kernel() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + canonical_kernel() + "_SOURCES", platform_nodist_sources(platform) + "## platform nodist sources")
|
||||
r += var_add("nodist_" + canonical_kernel() + "_SOURCES", shared_nodist_sources() + "## shared nodist sources")
|
||||
r += var_set(canonical_kernel() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(canonical_kernel() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_KERNEL) " + platform_cflags(platform))
|
||||
r += var_set(canonical_kernel() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_KERNEL) " + platform_ldflags(platform))
|
||||
r += var_set(canonical_kernel() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_KERNEL) " + platform_cppflags(platform))
|
||||
r += var_set(canonical_kernel() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_KERNEL) " + platform_ccasflags(platform))
|
||||
r = set_canonical_name_suffix(".exec")
|
||||
r += gvar_add("noinst_PROGRAMS", "[+ name +].exec")
|
||||
r += var_set(cname() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(cname() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + cname() + "_SOURCES", platform_nodist_sources(platform) + " ## platform nodist sources")
|
||||
r += var_add("nodist_" + cname() + "_SOURCES", shared_nodist_sources() + " ## shared nodist sources")
|
||||
r += var_set(cname() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(cname() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_KERNEL) " + platform_cflags(platform))
|
||||
r += var_set(cname() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_KERNEL) " + platform_ldflags(platform))
|
||||
r += var_set(cname() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_KERNEL) " + platform_cppflags(platform))
|
||||
r += var_set(cname() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_KERNEL) " + platform_ccasflags(platform))
|
||||
r += var_set(cname() + "_STRIPFLAGS", "$(AM_STRIPFLAGS) $(STRIPFLAGS_KERNEL) " + platform_stripflags(platform))
|
||||
|
||||
r += gvar_add("EXTRA_DIST", platform_extra_dist(platform))
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + canonical_kernel() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + canonical_kernel() + "_SOURCES)")
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
|
||||
r += gvar_add("platform_DATA", "[+ name +].img")
|
||||
r += gvar_add("CLEANFILES", "[+ name +].img")
|
||||
r += rule("[+ name +].img", "[+ name +].exec$(EXEEXT)",
|
||||
if_platform_tagged(platform, "nostrip", lambda: "cp $@ $<",
|
||||
lambda: "$(STRIP) $(" + cname() + "_STRIPFLAGS) -o $@ $<"))
|
||||
return r
|
||||
|
||||
def image(platform):
|
||||
r = gvar_add("noinst_PROGRAMS", "[+ name +].image")
|
||||
r += var_set(canonical_image() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(canonical_image() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + canonical_image() + "_SOURCES", platform_nodist_sources(platform) + "## platform nodist sources")
|
||||
r += var_add("nodist_" + canonical_image() + "_SOURCES", shared_nodist_sources() + "## shared nodist sources")
|
||||
r += var_set(canonical_image() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(canonical_image() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_IMAGE) " + platform_cflags(platform))
|
||||
r += var_set(canonical_image() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_IMAGE) " + platform_ldflags(platform))
|
||||
r += var_set(canonical_image() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_IMAGE) " + platform_cppflags(platform))
|
||||
r += var_set(canonical_image() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_IMAGE) " + platform_ccasflags(platform))
|
||||
r = set_canonical_name_suffix(".image")
|
||||
r += gvar_add("noinst_PROGRAMS", "[+ name +].image")
|
||||
r += var_set(cname() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(cname() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + cname() + "_SOURCES", platform_nodist_sources(platform) + "## platform nodist sources")
|
||||
r += var_add("nodist_" + cname() + "_SOURCES", shared_nodist_sources() + "## shared nodist sources")
|
||||
r += var_set(cname() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(cname() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_IMAGE) " + platform_cflags(platform))
|
||||
r += var_set(cname() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_IMAGE) " + platform_ldflags(platform))
|
||||
r += var_set(cname() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_IMAGE) " + platform_cppflags(platform))
|
||||
r += var_set(cname() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_IMAGE) " + platform_ccasflags(platform))
|
||||
|
||||
r += gvar_add("EXTRA_DIST", platform_extra_dist(platform))
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + canonical_image() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + canonical_image() + "_SOURCES)")
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
|
||||
r += gvar_add("platform_DATA", "[+ name +].img")
|
||||
r += gvar_add("CLEANFILES", "[+ name +].img")
|
||||
|
@ -307,24 +281,25 @@ def image(platform):
|
|||
if test x$(USE_APPLE_CC_FIXES) = xyes; then \
|
||||
$(MACHO2IMG) $< $@; \
|
||||
else \
|
||||
$(OBJCOPY) -O """ + platform_format(platform) + """ --strip-unneeded -R .note -R .comment -R .note.gnu.build-id -R .reginfo -R .rel.dyn $< $@; \
|
||||
$(OBJCOPY) """ + platform_objcopyflags(platform) + """ --strip-unneeded -R .note -R .comment -R .note.gnu.build-id -R .reginfo -R .rel.dyn $< $@; \
|
||||
fi
|
||||
""")
|
||||
return r
|
||||
|
||||
def library(platform):
|
||||
r = gvar_add("noinst_LIBRARIES", "[+ name +]")
|
||||
r += var_set(canonical_name() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(canonical_name() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + canonical_name() + "_SOURCES", platform_nodist_sources(platform))
|
||||
r += var_add("nodist_" + canonical_name() + "_SOURCES", shared_nodist_sources())
|
||||
r += var_set(canonical_name() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_LIBRARY) " + platform_cflags(platform))
|
||||
r += var_set(canonical_name() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_LIBRARY) " + platform_cppflags(platform))
|
||||
r += var_set(canonical_name() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_LIBRARY) " + platform_ccasflags(platform))
|
||||
r = set_canonical_name_suffix("")
|
||||
r += gvar_add("noinst_LIBRARIES", "[+ name +]")
|
||||
r += var_set(cname() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(cname() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + cname() + "_SOURCES", platform_nodist_sources(platform))
|
||||
r += var_add("nodist_" + cname() + "_SOURCES", shared_nodist_sources())
|
||||
r += var_set(cname() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_LIBRARY) " + platform_cflags(platform))
|
||||
r += var_set(cname() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_LIBRARY) " + platform_cppflags(platform))
|
||||
r += var_set(cname() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_LIBRARY) " + platform_ccasflags(platform))
|
||||
|
||||
r += gvar_add("EXTRA_DIST", platform_extra_dist(platform))
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + canonical_name() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + canonical_name() + "_SOURCES)")
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
|
||||
return r
|
||||
|
||||
|
@ -344,46 +319,45 @@ PATH=$(builddir):$$PATH $(HELP2MAN) --section=[+ mansection +] -i $(top_srcdir)/
|
|||
return r
|
||||
|
||||
def program(platform, test=False):
|
||||
if test:
|
||||
r = gvar_add("check_PROGRAMS", "[+ name +]")
|
||||
else:
|
||||
r = gvar_add(installdir() + "_PROGRAMS", "[+ name +]")
|
||||
r = set_canonical_name_suffix("")
|
||||
|
||||
r += var_set(canonical_name() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(canonical_name() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + canonical_name() + "_SOURCES", platform_nodist_sources(platform))
|
||||
r += var_add("nodist_" + canonical_name() + "_SOURCES", shared_nodist_sources())
|
||||
r += var_set(canonical_name() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(canonical_name() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_PROGRAM) " + platform_cflags(platform))
|
||||
r += var_set(canonical_name() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_PROGRAM) " + platform_ldflags(platform))
|
||||
r += var_set(canonical_name() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_PROGRAM) " + platform_cppflags(platform))
|
||||
r += var_set(canonical_name() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_PROGRAM) " + platform_ccasflags(platform))
|
||||
r += "[+ IF testcase defined +]"
|
||||
r += gvar_add("check_PROGRAMS", "[+ name +]")
|
||||
r += gvar_add("TESTS", "[+ name +]")
|
||||
r += "[+ ELSE +]"
|
||||
r += gvar_add(installdir() + "_PROGRAMS", "[+ name +]")
|
||||
r += "[+ IF mansection +]" + manpage() + "[+ ENDIF +]"
|
||||
r += "[+ ENDIF +]"
|
||||
|
||||
r += var_set(cname() + "_SOURCES", platform_sources(platform))
|
||||
r += var_add(cname() + "_SOURCES", shared_sources())
|
||||
r += var_set("nodist_" + cname() + "_SOURCES", platform_nodist_sources(platform))
|
||||
r += var_add("nodist_" + cname() + "_SOURCES", shared_nodist_sources())
|
||||
r += var_set(cname() + "_LDADD", platform_ldadd(platform))
|
||||
r += var_set(cname() + "_CFLAGS", "$(AM_CFLAGS) $(CFLAGS_PROGRAM) " + platform_cflags(platform))
|
||||
r += var_set(cname() + "_LDFLAGS", "$(AM_LDFLAGS) $(LDFLAGS_PROGRAM) " + platform_ldflags(platform))
|
||||
r += var_set(cname() + "_CPPFLAGS", "$(AM_CPPFLAGS) $(CPPFLAGS_PROGRAM) " + platform_cppflags(platform))
|
||||
r += var_set(cname() + "_CCASFLAGS", "$(AM_CCASFLAGS) $(CCASFLAGS_PROGRAM) " + platform_ccasflags(platform))
|
||||
|
||||
r += gvar_add("EXTRA_DIST", platform_extra_dist(platform))
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + canonical_name() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + canonical_name() + "_SOURCES)")
|
||||
|
||||
if test:
|
||||
r += if_tag_defined("enable", lambda: gvar_add("TESTS", "[+ name +]"))
|
||||
else:
|
||||
r += if_tag("mansection", lambda: manpage())
|
||||
|
||||
r += gvar_add("BUILT_SOURCES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
r += gvar_add("CLEANFILES", "$(nodist_" + cname() + "_SOURCES)")
|
||||
return r
|
||||
|
||||
def test_program(platform):
|
||||
return program(platform, True)
|
||||
|
||||
def data(platform):
|
||||
r = gvar_add("EXTRA_DIST", platform_sources(platform))
|
||||
r += gvar_add("EXTRA_DIST", platform_extra_dist(platform))
|
||||
r += gvar_add(installdir() + "_DATA", platform_sources(platform))
|
||||
return r
|
||||
|
||||
def script(platform, test=False):
|
||||
if test:
|
||||
r = gvar_add("check_SCRIPTS", "[+ name +]")
|
||||
else:
|
||||
r = gvar_add(installdir() + "_SCRIPTS", "[+ name +]")
|
||||
def script(platform):
|
||||
r = "[+ IF testcase defined +]"
|
||||
r += gvar_add("check_SCRIPTS", "[+ name +]")
|
||||
r += gvar_add ("TESTS", "[+ name +]")
|
||||
r += "[+ ELSE +]"
|
||||
r += gvar_add(installdir() + "_SCRIPTS", "[+ name +]")
|
||||
r += "[+ IF mansection +]" + manpage() + "[+ ENDIF +]"
|
||||
r += "[+ ENDIF +]"
|
||||
|
||||
r += rule("[+ name +]", "$(top_builddir)/config.status " + platform_sources(platform), """
|
||||
$(top_builddir)/config.status --file=-:""" + platform_sources(platform) + """ \
|
||||
|
@ -393,46 +367,28 @@ chmod a+x [+ name +]
|
|||
|
||||
r += gvar_add("CLEANFILES", "[+ name +]")
|
||||
r += gvar_add("EXTRA_DIST", platform_sources(platform))
|
||||
|
||||
if test:
|
||||
r += if_tag_defined("enable", lambda: gvar_add("TESTS", "[+ name +]"))
|
||||
else:
|
||||
r += if_tag("mansection", lambda: manpage())
|
||||
|
||||
return r
|
||||
|
||||
def test_script(platform):
|
||||
return script(platform, True)
|
||||
|
||||
def with_enable_condition(x):
|
||||
return "[+ IF enable +]if [+ enable +]\n" + x + "endif\n[+ ELSE +]" + x + "[+ ENDIF +]"
|
||||
|
||||
def module_rules():
|
||||
return for_tag("module", lambda: with_enable_condition(each_platform(lambda p: module(p))))
|
||||
return "[+ FOR module +]" + under_conditional(each_platform(lambda p: module(p))) + "[+ ENDFOR +]"
|
||||
|
||||
def kernel_rules():
|
||||
return for_tag("kernel", lambda: with_enable_condition(each_platform(lambda p: kernel(p))))
|
||||
return "[+ FOR kernel +]" + under_conditional(each_platform(lambda p: kernel(p))) + "[+ ENDFOR +]"
|
||||
|
||||
def image_rules():
|
||||
return for_tag("image", lambda: with_enable_condition(each_platform(lambda p: image(p))))
|
||||
return "[+ FOR image +]" + under_conditional(each_platform(lambda p: image(p))) + "[+ ENDFOR +]"
|
||||
|
||||
def library_rules():
|
||||
return for_tag("library", lambda: with_enable_condition(each_platform(lambda p: library(p))))
|
||||
return "[+ FOR library +]" + under_conditional(each_platform(lambda p: library(p))) + "[+ ENDFOR +]"
|
||||
|
||||
def program_rules():
|
||||
return for_tag("program", lambda: with_enable_condition(each_platform(lambda p: program(p))))
|
||||
return "[+ FOR program +]" + under_conditional(each_platform(lambda p: program(p))) + "[+ ENDFOR +]"
|
||||
|
||||
def script_rules():
|
||||
return for_tag("script", lambda: with_enable_condition(each_platform(lambda p: script(p))))
|
||||
return "[+ FOR script +]" + under_conditional(each_platform(lambda p: script(p))) + "[+ ENDFOR +]"
|
||||
|
||||
def data_rules():
|
||||
return for_tag("data", lambda: with_enable_condition(each_platform(lambda p: data(p))))
|
||||
|
||||
def test_program_rules():
|
||||
return for_tag("test_program", lambda: with_enable_condition(each_platform(lambda p: test_program(p))))
|
||||
|
||||
def test_script_rules():
|
||||
return for_tag("test_script", lambda: with_enable_condition(each_platform(lambda p: test_script(p))))
|
||||
return "[+ FOR data +]" + under_conditional(each_platform(lambda p: data(p))) + "[+ ENDFOR +]"
|
||||
|
||||
print "[+ AutoGen5 template +]\n"
|
||||
a = module_rules()
|
||||
|
@ -442,11 +398,9 @@ d = library_rules()
|
|||
e = program_rules()
|
||||
f = script_rules()
|
||||
g = data_rules()
|
||||
h = test_program_rules()
|
||||
i = test_script_rules()
|
||||
z = global_variable_initializers()
|
||||
|
||||
print z # initializer for all vars
|
||||
# print z # initializer for all vars
|
||||
print a
|
||||
print b
|
||||
print c
|
||||
|
@ -454,8 +408,6 @@ print d
|
|||
print e
|
||||
print f
|
||||
print g
|
||||
print h
|
||||
print i
|
||||
|
||||
print """.PRECIOUS: modules.am
|
||||
$(srcdir)/modules.am: $(srcdir)/modules.def $(top_srcdir)/Makefile.tpl
|
||||
|
|
|
@ -33,6 +33,8 @@ dnl package (in grub-core directory) builds with TARGETCC.
|
|||
AC_INIT([GRUB],[1.98],[bug-grub@gnu.org])
|
||||
AC_CONFIG_AUX_DIR([.])
|
||||
|
||||
: ${CFLAGS=""} # We don't want -g -O2
|
||||
|
||||
# Checks for host and target systems.
|
||||
AC_CANONICAL_HOST
|
||||
AC_CANONICAL_TARGET
|
||||
|
|
File diff suppressed because it is too large
Load diff
119
modules.def
119
modules.def
|
@ -90,7 +90,6 @@ library = {
|
|||
source = grub-core/script/lexer.c;
|
||||
source = grub-core/script/main.c;
|
||||
source = grub-core/script/script.c;
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -99,7 +98,6 @@ program = {
|
|||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
mansection = 1;
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -114,7 +112,6 @@ program = {
|
|||
ldadd = '$(LIBINTL)';
|
||||
|
||||
cppflags = '-DGRUB_PKGLIBROOTDIR=\"$(pkglibrootdir)\"';
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -125,7 +122,6 @@ program = {
|
|||
|
||||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -136,7 +132,6 @@ program = {
|
|||
|
||||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -147,7 +142,6 @@ program = {
|
|||
|
||||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -160,13 +154,13 @@ program = {
|
|||
ldadd = '$(LIBINTL)';
|
||||
cflags = '$(CFLAGS_GCRY)';
|
||||
cppflags = '$(CPPFLAGS_GCRY)';
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
name = grub-macho2img;
|
||||
mansection = 1;
|
||||
source = util/grub-macho2img.c;
|
||||
condition = COND_APPLE_CC;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -176,8 +170,7 @@ program = {
|
|||
|
||||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
enable = COND_GRUB_PE2ELF;
|
||||
common;
|
||||
condition = COND_GRUB_PE2ELF;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -187,8 +180,7 @@ program = {
|
|||
|
||||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
enable = COND_GRUB_FSTEST;
|
||||
common;
|
||||
condition = COND_GRUB_FSTEST;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -202,9 +194,7 @@ program = {
|
|||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
ldadd = '$(freetype_libs)';
|
||||
|
||||
common;
|
||||
enable = COND_GRUB_MKFONT;
|
||||
condition = COND_GRUB_MKFONT;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -223,7 +213,6 @@ program = {
|
|||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
ldadd = '$(LIBUTIL)';
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -235,7 +224,6 @@ program = {
|
|||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
ldadd = '$(LIBUTIL)';
|
||||
common;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -254,6 +242,9 @@ program = {
|
|||
ldadd = libgrub.a;
|
||||
ldadd = '$(LIBINTL)';
|
||||
ldadd = '$(LIBUTIL)';
|
||||
|
||||
enable = i386_pc;
|
||||
enable = sparc64_ieee1275;
|
||||
};
|
||||
|
||||
program = {
|
||||
|
@ -263,20 +254,18 @@ program = {
|
|||
source = util/ieee1275/ofpath.c;
|
||||
|
||||
ldadd = libgrub.a;
|
||||
sparc64_ieee1275;
|
||||
enable = sparc64_ieee1275;
|
||||
};
|
||||
|
||||
data = {
|
||||
source = util/grub.d/README;
|
||||
installdir = grubconf;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
name = '00_header';
|
||||
source = util/grub.d/00_header.in;
|
||||
installdir = grubconf;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
|
@ -295,28 +284,24 @@ script = {
|
|||
name = '10_linux';
|
||||
source = util/grub.d/10_linux.in;
|
||||
installdir = grubconf;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
name = '30_os-prober';
|
||||
source = util/grub.d/30_os-prober.in;
|
||||
installdir = grubconf;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
name = '40_custom';
|
||||
source = util/grub.d/40_custom.in;
|
||||
installdir = grubconf;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
name = '41_custom';
|
||||
source = util/grub.d/41_custom.in;
|
||||
installdir = grubconf;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
|
@ -324,9 +309,10 @@ script = {
|
|||
name = grub-mkrescue;
|
||||
source = util/grub-mkrescue.in;
|
||||
powerpc_ieee1275 = util/powerpc/ieee1275/grub-mkrescue.in;
|
||||
i386_pc;
|
||||
i386_qemu;
|
||||
i386_coreboot;
|
||||
enable = i386_pc;
|
||||
enable = i386_qemu;
|
||||
enable = i386_coreboot;
|
||||
enable = powerpc_ieee1275;
|
||||
};
|
||||
|
||||
script = {
|
||||
|
@ -337,10 +323,10 @@ script = {
|
|||
x86_efi = util/i386/efi/grub-install.in;
|
||||
i386_ieee1275 = util/ieee1275/grub-install.in;
|
||||
powerpc_ieee1275 = util/ieee1275/grub-install.in;
|
||||
mips;
|
||||
i386_pc;
|
||||
i386_qemu;
|
||||
i386_coreboot;
|
||||
|
||||
enable = x86;
|
||||
enable = mips;
|
||||
enable = powerpc_ieee1275;
|
||||
};
|
||||
|
||||
script = {
|
||||
|
@ -348,7 +334,6 @@ script = {
|
|||
source = util/grub-mkconfig.in;
|
||||
mansection = 8;
|
||||
installdir = sbin;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
|
@ -356,7 +341,6 @@ script = {
|
|||
source = util/grub-set-default.in;
|
||||
mansection = 8;
|
||||
installdir = sbin;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
|
@ -364,118 +348,104 @@ script = {
|
|||
source = util/grub-reboot.in;
|
||||
mansection = 8;
|
||||
installdir = sbin;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
name = grub-mkconfig_lib;
|
||||
source = util/grub-mkconfig_lib.in;
|
||||
installdir = pkglib;
|
||||
common;
|
||||
};
|
||||
|
||||
script = {
|
||||
name = update-grub_lib;
|
||||
source = util/update-grub_lib.in;
|
||||
installdir = pkglib;
|
||||
common;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
name = grub-shell;
|
||||
source = tests/util/grub-shell.in;
|
||||
common;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
name = grub-shell-tester;
|
||||
source = tests/util/grub-shell-tester.in;
|
||||
common;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = example_scripted_test;
|
||||
source = tests/example_scripted_test.in;
|
||||
common;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = example_grub_script_test;
|
||||
source = tests/example_grub_script_test.in;
|
||||
common;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_echo1;
|
||||
source = tests/grub_script_echo1.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_echo_keywords;
|
||||
source = tests/grub_script_echo_keywords.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_vars1;
|
||||
source = tests/grub_script_vars1.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_for1;
|
||||
source = tests/grub_script_for1.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_while1;
|
||||
source = tests/grub_script_while1.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_if;
|
||||
source = tests/grub_script_if.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_blanklines;
|
||||
source = tests/grub_script_blanklines.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_final_semicolon;
|
||||
source = tests/grub_script_final_semicolon.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_dollar;
|
||||
source = tests/grub_script_dollar.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_script = {
|
||||
script = {
|
||||
testcase;
|
||||
name = grub_script_comments;
|
||||
source = tests/grub_script_comments.in;
|
||||
common;
|
||||
enable;
|
||||
};
|
||||
|
||||
test_program = {
|
||||
program = {
|
||||
testcase;
|
||||
name = example_unit_test;
|
||||
source = tests/example_unit_test.c;
|
||||
source = tests/lib/unit_test.c;
|
||||
|
@ -484,5 +454,4 @@ test_program = {
|
|||
source = grub-core/tests/lib/test.c;
|
||||
cflags = -Wno-format;
|
||||
ldadd = libgrub.a;
|
||||
common;
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue