]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
make build by default
authorBVK Chaitanya <bvk.groups@gmail.com>
Tue, 13 Jul 2010 18:05:24 +0000 (23:35 +0530)
committerBVK Chaitanya <bvk.groups@gmail.com>
Tue, 13 Jul 2010 18:05:24 +0000 (23:35 +0530)
configure.common
gentpl.py
grub-core/configure.ac
grub-core/modules.def
modules.def

index 46a3fd5e4c1f2b911e02d9b1032fea9240904f66..a9e5665dd16022a70218e2ca35adc635195a8bcc 100644 (file)
@@ -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])
index de2efe80aeaae77c8f20aa4efba6de47fef08309..5081cf4832fb8ace628c7338ef0af5425ae551c5 100644 (file)
--- a/gentpl.py
+++ b/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 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 each_group(platform, suffix, closure):
-    r = None
+def if_platform_tagged(platform, tag, closure, c2=None):
+    r = ""
+    r += "[+ IF " + tag + " defined +]"
+    r += "[+ FOR " + tag + " +][+ CASE " + tag + " +]"
     for group in RMAP[platform]:
-        if r == None:
-            r = "[+ IF ." + group + suffix + " +]"
-        else:
-            r += "[+ ELIF ." + group + suffix + " +]"
-            
-        r += closure(group)
+        r += "[+ = \"" + group + "\" +]" + closure()
+    r += "[+ ESAC +][+ ENDFOR +]"
 
-    if r:
-        r += "[+ ELSE +]"
-        r += closure(None)
+    if c2 == None:
         r += "[+ ENDIF +]"
-    else:
-        r = closure(None)
+        return r
 
+    r += "[+ ELSE +]" + c2() + "[+ ENDIF +]"
     return r
 
-def each_platform(closure):
+def platform_values(platform, group_tag, default_tag):
     r = ""
-    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 += "if COND_" + platform + "\n"
-            r += closure(platform)
-            r += "endif\n"
-        r += "[+ ENDIF +]"
+    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 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 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 under_conditional(x):
+    return "[+ IF condition +]\nif [+ condition +]\n[+ ENDIF +]" + x + "[+ IF condition +]\nendif\n[+ ENDIF +]"
+
+def each_platform(closure):
+    r = "[+ IF - enable undefined +]"
+    for platform in GRUB_PLATFORMS:
+        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;
+
+def shared_sources(): return "[+ FOR shared +][+ .shared +] [+ ENDFOR +]"
+def shared_nodist_sources(): return "[+ FOR nodist_shared +] [+ .nodist_shared +][+ ENDFOR +]"
+
+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 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 += 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 = set_canonical_name_suffix("")
+
+    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
index 7c3175feaceadd2a3595a20424683cf70dde662a..5ba5962a3579344760aae6a303343c3ff6aff511 100644 (file)
@@ -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
index 08eb6e4ea011b4abc49305d54de8d238d3f54de8..b63c709228d95763dc04e548d242b7fad6b30d05 100644 (file)
@@ -3,8 +3,9 @@ AutoGen definitions Makefile.tpl;
 kernel = {
   name = kernel;
 
-  emu_ldflags              = '-Wl,-r';
-  x86_efi_ldflags          = '-Wl,-r';
+  emu_ldflags              = '-Wl,-r,-d';
+  x86_efi_ldflags          = '-Wl,-r,-d';
+  x86_efi_stripflags       = '--strip-unneeded -K start -R .note -R .comment';
 
   i386_pc_ldflags          = '$(TARGET_IMG_LDFLAGS)';
   i386_pc_ldflags          = '$(TARGET_IMG_BASE_LDOPT),$(GRUB_KERNEL_MACHINE_LINK_ADDR)';
@@ -246,7 +247,7 @@ program = {
   ldadd = '$(MODULE_FILES)';
   ldadd = '$(LIBCURSES) $(LIBSDL) $(LIBUSB) $(LIBPCIACCESS)';
 
-  emu;
+  enable = emu;
 };
 
 program = {
@@ -259,7 +260,7 @@ program = {
   ldadd = 'kernel.img$(EXEEXT)';
   ldadd = '$(LIBCURSES) $(LIBSDL) $(LIBUSB) $(LIBPCIACCESS)';
 
-  emu;
+  enable = emu;
 };
 
 image = {
@@ -275,8 +276,13 @@ image = {
   i386_qemu_ccasflags = '-DGRUB_BOOT_MACHINE_LINK_ADDR=$(GRUB_BOOT_MACHINE_LINK_ADDR)';
 
   sparc64_ieee1275 = boot/sparc64/ieee1275/boot.S;
-  sparc64_ieee1275_format = a.out-sunos-big;
+  sparc64_ieee1275_objcopyflags = '-O a.out-sunos-big';
   sparc64_ieee1275_ldflags = ' -Wl,-Ttext=0x4000';
+
+  objcopyflags = '-O binary';
+  enable = i386_pc;
+  enable = i386_qemu;
+  enable = sparc64_ieee1275;
 };
 
 image = {
@@ -284,6 +290,8 @@ image = {
   i386_pc = boot/i386/pc/cdboot.S;
   i386_pc_ldflags = '$(TARGET_IMG_LDFLAGS)';
   i386_pc_ldflags = '$(TARGET_IMG_BASE_LDOPT),0x7C00';
+  objcopyflags = '-O binary';
+  enable = i386_pc;
 };
 
 image = {
@@ -292,6 +300,9 @@ image = {
 
   i386_pc_ldflags = '$(TARGET_IMG_LDFLAGS)';
   i386_pc_ldflags = '$(TARGET_IMG_BASE_LDOPT),0x7C00';
+
+  objcopyflags = '-O binary';
+  enable = i386_pc;
 };
 
 image = {
@@ -303,6 +314,11 @@ image = {
 
   sparc64_ieee1275 = boot/sparc64/ieee1275/diskboot.S;
   sparc64_ieee1275_ldflags = '-Wl,-Ttext=0x4200';
+
+  objcopyflags = '-O binary';
+
+  enable = i386_pc;
+  enable = sparc64_ieee1275;
 };
 
 image = {
@@ -311,44 +327,49 @@ image = {
 
   i386_pc_ldflags = '$(TARGET_IMG_LDFLAGS)';
   i386_pc_ldflags = '$(TARGET_IMG_BASE_LDOPT),0x6000';
+
+  objcopyflags = '-O binary';
+  enable = i386_pc;
 };
 
 image = {
   name = fwstart;
   mips_yeeloong = boot/mips/yeeloong/fwstart.S;
+  objcopyflags = '-O binary';
+  enable = mips_yeeloong;
 };
 
 module = {
   name = trig;
   nodist = trigtables.c;
   extra_dist = gentrigtables.c;
-  common;
 };
 
 module = {
   name = cs5536;
   source = bus/cs5536.c;
-  i386;
+  enable = i386;
 };
 
 module = {
   name = libusb;
   source = bus/usb/emu/usb.c;
-  emu;
-  enable = COND_GRUB_EMU_USB;
+  enable = emu;
+  condition = COND_GRUB_EMU_USB;
 };
 
 module = {
   name = lsspd;
   mips_yeeloong = commands/mips/yeeloong/lsspd.c;
+  enable = mips_yeeloong;
 };
 
 module = {
   name = pci;
   source = bus/emu/pci.c;
   source = commands/lspci.c;
-  emu;
-  enable = COND_GRUB_EMU_PCI;
+  enable = emu;
+  condition = COND_GRUB_EMU_PCI;
 };
 
 module = {
@@ -356,37 +377,37 @@ module = {
   source = bus/usb/usb.c;
   source = bus/usb/usbtrans.c;
   source = bus/usb/usbhub.c;
-  i386;
-  mips_yeeloong;
+  enable = i386;
+  enable = mips_yeeloong;
 };
 
 module = {
   name = usb;
   source = bus/usb/usb.c;
-  emu;
-  enable = COND_GRUB_EMU_USB;
+  enable = emu;
+  condition = COND_GRUB_EMU_USB;
 };
 
 module = {
   name = uhci;
   source = bus/usb/uhci.c;
-  x86;
+  enable = x86;
 };
 
 module = {
   name = ohci;
   source = bus/usb/ohci.c;
-  x86;
-  mips_yeeloong;
+  enable = x86;
+  enable = mips_yeeloong;
 };
 
 module = {
   name = pci;
   source = bus/pci.c;
-  i386_pc;
-  i386_efi;
-  i386_ieee1275;
-  i386_coreboot;
+  enable = i386_pc;
+  enable = i386_efi;
+  enable = i386_ieee1275;
+  enable = i386_coreboot;
 };
 
 library = {
@@ -400,13 +421,12 @@ library = {
 
   cflags = '$(CFLAGS_POSIX) $(CFLAGS_GNULIB)';
   cppflags = '$(CPPFLAGS_POSIX) $(CPPFLAGS_GNULIB)';
-  common;
 };
 
 module = {
   name = iorw;
   source = commands/iorw.c;
-  i386;
+  enable = i386;
 };
 
 module = {
@@ -415,7 +435,6 @@ module = {
   ldadd = libgnulib.a;
   cflags = '$(CFLAGS_POSIX) $(CFLAGS_GNULIB)';
   cppflags = '$(CPPFLAGS_POSIX) $(CPPFLAGS_GNULIB)';
-  common;
 };
 
 module = {
@@ -426,16 +445,17 @@ module = {
 
   i386_pc = commands/acpi.c;
   i386_pc = commands/i386/pc/acpi.c;
+
+  enable = x86_efi;
+  enable = i386_pc;
 };
 
 module = {
-  common;
   name = blocklist;
   source = commands/blocklist.c;
 };
 
 module = {
-  common;
   name = boot;
   source = commands/boot.c;
 
@@ -444,19 +464,16 @@ module = {
 };
 
 module = {
-  common;
   name = cat;
   source = commands/cat.c;
 };
 
 module = {
-  common;
   name = cmp;
   source = commands/cmp.c;
 };
 
 module = {
-  common;
   name = configfile;
   source = commands/configfile.c;
 };
@@ -465,23 +482,18 @@ module = {
   name = cpuid;
   source = commands/i386/cpuid.c;
 
-  x86;
+  enable = x86;
 };
 
 module = {
-  common;
   name = crc;
   source = commands/crc.c;
   source = lib/crc.c;
 };
 
 module = {
-  common;
   name = date;
   source = commands/date.c;
-
-  x86;
-  mips;
 };
 
 module = {
@@ -489,16 +501,15 @@ module = {
 
   i386_pc = commands/i386/pc/drivemap.c;
   i386_pc = commands/i386/pc/drivemap_int13h.S;
+  enable = i386_pc;
 };
 
 module = {
-  common;
   name = echo;
   source = commands/echo.c;
 };
 
 module = {
-  common;
   name = extcmd;
   source = commands/extcmd.c;
   source = lib/arg.c;
@@ -507,10 +518,10 @@ module = {
 module = {
   name = fixvideo;
   x86_efi = commands/efi/fixvideo.c;
+  enable = x86_efi;
 };
 
 module = {
-  common;
   name = gptsync;
   source = commands/gptsync.c;
 };
@@ -520,15 +531,9 @@ module = {
   source = commands/halt.c;
 
   i386_pc = commands/i386/pc/halt.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
-  mips_yeeloong;
 };
 
 module = {
-  common;
   name = hashsum;
   source = commands/hashsum.c;
 };
@@ -538,24 +543,21 @@ module = {
   source = commands/hdparm.c;
   source = lib/hexdump.c;
 
-  i386_pc;
+  enable = i386_pc;
 };
 
 module = {
-  common;
   name = help;
   source = commands/help.c;
 };
 
 module = {
-  common;
   name = hexdump;
   source = commands/hexdump.c;
   source = lib/hexdump.c;
 };
 
 module = {
-  common;
   name = keystatus;
   source = commands/keystatus.c;
 };
@@ -563,69 +565,62 @@ module = {
 module = {
   name = loadbios;
   x86_efi = commands/efi/loadbios.c;
+  enable = x86_efi;
 };
 
 module = {
-  common;
   name = loadenv;
   source = commands/loadenv.c;
   source = lib/envblk.c;
 };
 
 module = {
-  common;
   name = ls;
   source = commands/ls.c;
 };
 
 module = {
-  common;
   name = lsmmap;
   source = commands/lsmmap.c;
 
-  i386_pc;
-  i386_qemu;
-  i386_coreboot;
-  i386_multiboot;
-  i386_ieee1275;
-  mips_yeeloong;
-  powerpc_ieee1275;
+  enable = i386_pc;
+  enable = i386_qemu;
+  enable = i386_coreboot;
+  enable = i386_multiboot;
+  enable = i386_ieee1275;
+  enable = mips_yeeloong;
+  enable = powerpc_ieee1275;
 };
 
 module = {
   name = lspci;
   source = commands/lspci.c;
 
-  x86;
-  mips;
+  enable = x86;
+  enable = mips;
 };
 
 module = {
-  common;
   name = memrw;
   source = commands/memrw.c;
 };
 
 module = {
-  common;
   name = minicmd;
   source = commands/minicmd.c;
 };
 
 module = {
-  common;
   name = parttool;
   source = commands/parttool.c;
 };
 
 module = {
-  common;
   name = password;
   source = commands/password.c;
 };
 
 module = {
-  common;
   name = password_pbkdf2;
   source = commands/password_pbkdf2.c;
 };
@@ -633,11 +628,10 @@ module = {
 module = {
   name = play;
   source = commands/i386/pc/play.c;
-  i386;
+  enable = i386;
 };
 
 module = {
-  common;
   name = probe;
   source = commands/probe.c;
 };
@@ -645,43 +639,36 @@ module = {
 module = {
   name = pxecmd;
   i386_pc = commands/i386/pc/pxecmd.c;
+  enable = i386_pc;
 };
 
 module = {
-  common;
   name = read;
   source = commands/read.c;
 };
 
 module = {
-  common;
   name = reboot;
   source = commands/reboot.c;
-
-  x86; powerpc; sparc64;
 };
 
 module = {
-  common;
   name = search;
   source = commands/search_wrap.c;
   extra_dist = commands/search.c;
 };
 
 module = {
-  common;
   name = search_fs_file;
   source = commands/search_file.c;
 };
 
 module = {
-  common;
   name = search_fs_uuid;
   source = commands/search_uuid.c;
 };
 
 module = {
-  common;
   name = search_label;
   source = commands/search_label.c;
 };
@@ -690,11 +677,10 @@ module = {
   name = setpci;
   source = commands/setpci.c;
 
-  x86;
+  enable = x86;
 };
 
 module = {
-  common;
   name = sleep;
   source = commands/sleep.c;
 };
@@ -702,24 +688,21 @@ module = {
 module = {
   name = suspend;
   source = commands/ieee1275/suspend.c;
-  i386_ieee1275;
-  powerpc_ieee1275;
+  enable = i386_ieee1275;
+  enable = powerpc_ieee1275;
 };
 
 module = {
-  common;
   name = terminal;
   source = commands/terminal.c;
 };
 
 module = {
-  common;
   name = test;
   source = commands/test.c;
 };
 
 module = {
-  common;
   name = true;
   source = commands/true.c;
 };
@@ -727,89 +710,80 @@ module = {
 module = {
   name = usbtest;
   source = commands/usbtest.c;
-  i386_pc;
-  mips_yeeloong;
+  enable = i386_pc;
+  enable = mips_yeeloong;
 };
 
 module = {
   name = usbtest;
   source = commands/usbtest.c;
-  emu;
-  enable = COND_GRUB_EMU_USB;
+  enable = emu;
+  condition = COND_GRUB_EMU_USB;
 };
 
 module = {
   name = vbeinfo;
   i386_pc = commands/i386/pc/vbeinfo.c;
+  enable = i386_pc;
 };
 
 module = {
   name = vbetest;
   i386_pc = commands/i386/pc/vbetest.c;
+  enable = i386_pc;
 };
 
 module = {
-  common;
   name = videotest;
   source = commands/videotest.c;
 };
 
 module = {
-  common;
   name = xnu_uuid;
   source = commands/xnu_uuid.c;
 };
 
 module = {
-  common;
   name = dm_nv;
   source = disk/dmraid_nvidia.c;
 };
 
 module = {
-  common;
   name = loopback;
   source = disk/loopback.c;
 };
 
 module = {
-  common;
   name = lvm;
   source = disk/lvm.c;
 };
 
 module = {
-  common;
   name = mdraid;
   source = disk/mdraid_linux.c;
 };
 
 module = {
-  common;
   name = raid;
   source = disk/raid.c;
 };
 
 module = {
-  common;
   name = raid5rec;
   source = disk/raid5_recover.c;
 };
 
 module = {
-  common;
   name = raid6rec;
   source = disk/raid6_recover.c;
 };
 
 module = {
-  common;
   name = scsi;
   source = disk/scsi.c;
 };
 
 module = {
-  common;
   name = memdisk;
   source = disk/memdisk.c;
 };
@@ -818,42 +792,43 @@ module = {
   name = ata;
   source = disk/ata.c;
 
-  x86;
-  mips;
+  enable = x86;
+  enable = mips;
 };
 
 module = {
   name = ata_pthru;
   source = disk/ata_pthru.c;
 
-  x86;
-  mips_yeeloong;
+  enable = x86;
+  enable = mips_yeeloong;
 };
 
 module = {
   name = biosdisk;
   i386_pc = disk/i386/pc/biosdisk.c;
+  enable = i386_pc;
 };
 
 module = {
   name = usbms;
   source = disk/usbms.c;
-  i386_pc;
-  mips_yeeloong;
+  enable = i386_pc;
+  enable = mips_yeeloong;
 };
 
 module = {
   name = usbms;
   source = disk/usbms.c;
-  emu;
-  enable = COND_GRUB_EMU_USB;
+  enable = emu;
+  condition = COND_GRUB_EMU_USB;
 };
 
 module = {
   name = nand;
   source = disk/ieee1275/nand.c;
 
-  i386_ieee1275;
+  enable = i386_ieee1275;
 };
 
 module = {
@@ -876,158 +851,136 @@ module = {
   extra_dist = efiemu/loadcore.c;
   extra_dist = efiemu/runtime/efiemu.S;
   extra_dist = efiemu/runtime/efiemu.c;
+
+  enable = i386_pc;
 };
 
 module = {
   name = font;
   source = font/font.c;
   source = font/font_cmd.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
+  enable = emu;
+  enable = x86;
+  enable = sparc64;
+  enable = powerpc;
 };
 
 module = {
-  common;
   name = affs;
   source = fs/affs.c;
 };
 
 module = {
-  common;
   name = afs;
   source = fs/afs.c;
 };
 
 module = {
-  common;
   name = afs_be;
   source = fs/afs_be.c;
 };
 
 module = {
-  common;
   name = befs;
   source = fs/befs.c;
 };
 
 module = {
-  common;
   name = befs_be;
   source = fs/befs_be.c;
 };
 
 module = {
-  common;
   name = cpio;
   source = fs/cpio.c;
 };
 
 module = {
-  common;
   name = ext2;
   source = fs/ext2.c;
 };
 
 module = {
-  common;
   name = fat;
   source = fs/fat.c;
 };
 
 module = {
-  common;
   name = fshelp;
   source = fs/fshelp.c;
 };
 
 module = {
-  common;
   name = hfs;
   source = fs/hfs.c;
 };
 
 module = {
-  common;
   name = hfsplus;
   source = fs/hfsplus.c;
 };
 
 module = {
-  common;
   name = iso9660;
   source = fs/iso9660.c;
 };
 
 module = {
-  common;
   name = jfs;
   source = fs/jfs.c;
 };
 
 module = {
-  common;
   name = minix;
   source = fs/minix.c;
 };
 
 module = {
-  common;
   name = nilfs2;
   source = fs/nilfs2.c;
 };
 
 module = {
-  common;
   name = ntfs;
   source = fs/ntfs.c;
 };
 
 module = {
-  common;
   name = ntfscomp;
   source = fs/ntfscomp.c;
 };
 
 module = {
-  common;
   name = reiserfs;
   source = fs/reiserfs.c;
 };
 
 module = {
-  common;
   name = sfs;
   source = fs/sfs.c;
 };
 
 module = {
-  common;
   name = tar;
   source = fs/tar.c;
 };
 
 module = {
-  common;
   name = udf;
   source = fs/udf.c;
 };
 
 module = {
-  common;
   name = ufs1;
   source = fs/ufs.c;
 };
 
 module = {
-  common;
   name = ufs2;
   source = fs/ufs2.c;
 };
 
 module = {
-  common;
   name = xfs;
   source = fs/xfs.c;
 };
@@ -1035,16 +988,15 @@ module = {
 module = {
   name = pxe;
   i386_pc = fs/i386/pc/pxe.c;
+  enable = i386_pc;
 };
 
 module = {
   name = gettext;
   source = gettext/gettext.c;
-  common;
 };
 
 module = {
-  common;
   name = gfxmenu;
   source = gfxmenu/gfxmenu.c;
   source = gfxmenu/model.c;
@@ -1066,13 +1018,11 @@ module = {
 };
 
 module = {
-  common;
   name = hello;
   source = hello/hello.c;
 };
 
 module = {
-  common;
   name = gzio;
   source = io/gzio.c;
 };
@@ -1080,20 +1030,18 @@ module = {
 module = {
   name = bufio;
   source = io/bufio.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
+  enable = emu;
+  enable = x86;
+  enable = sparc64;
+  enable = powerpc;
 };
 
 module = {
-  common;
   name = elf;
   source = kern/elf.c;
 };
 
 module = {
-  common;
   name = crypto;
   source = lib/crypto.c;
 
@@ -1101,7 +1049,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_arcfour;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1109,7 +1056,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_blowfish;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1117,7 +1063,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_camellia;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1126,7 +1071,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_cast5;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1134,7 +1078,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_crc;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1142,7 +1085,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_des;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1150,7 +1092,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_md4;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1158,7 +1099,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_md5;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1166,7 +1106,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_rfc2268;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1174,7 +1113,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_rijndael;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1182,7 +1120,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_rmd160;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1190,7 +1127,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_seed;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1198,7 +1134,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_serpent;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1206,7 +1141,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_sha1;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1214,7 +1148,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_sha256;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1222,7 +1155,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_sha512;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1230,7 +1162,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_tiger;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1238,7 +1169,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_twofish;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1246,7 +1176,6 @@ module = {
 };
 
 module = {
-  common;
   name = gcry_whirlpool;
   cflags = '$(CFLAGS_GCRY)';
   cppflags = '$(CPPFLAGS_GCRY)';
@@ -1254,7 +1183,6 @@ module = {
 };
 
 module = {
-  common;
   name = pbkdf2;
   source = lib/pbkdf2.c;
 };
@@ -1267,6 +1195,8 @@ module = {
   x86 = lib/i386/relocator_asm.S;
   x86 = lib/i386/relocator_backward.S;
   extra_dist = lib/relocator.c;
+  enable = mips;
+  enable = x86;
 };
 
 module = {
@@ -1275,8 +1205,10 @@ module = {
   x86_efi = lib/efi/datetime.c;
   sparc64_ieee1275 = lib/ieee1275/datetime.c;
   powerpc_ieee1275 = lib/ieee1275/datetime.c;
-  x86;
-  mips;
+  enable = x86;
+  enable = mips;
+  enable = sparc64_ieee1275;
+  enable = powerpc_ieee1275;
 };
 
 module = {
@@ -1291,11 +1223,11 @@ module = {
 module = {
   name = aout;
   source = loader/aout.c;
-  i386_pc;
-  i386_qemu;
-  i386_coreboot;
-  i386_multiboot;
-  i386_ieee1275;
+  enable = i386_pc;
+  enable = i386_qemu;
+  enable = i386_coreboot;
+  enable = i386_multiboot;
+  enable = i386_ieee1275;
 };
 
 module = {
@@ -1309,16 +1241,16 @@ module = {
   extra_dist = loader/i386/bsdXX.c;
   extra_dist = loader/i386/bsd_pagetable.c;
 
-  i386_pc;
-  i386_qemu;
-  i386_coreboot;
-  i386_multiboot;
+  enable = i386_pc;
+  enable = i386_qemu;
+  enable = i386_coreboot;
+  enable = i386_multiboot;
 };
 
 module = {
   name = linux16;
   source = loader/i386/pc/linux.c;
-  i386_pc;
+  enable = i386_pc;
 };
 
 module = {
@@ -1327,8 +1259,8 @@ module = {
 
   source = loader/multiboot.c;
   source = loader/multiboot_mbi2.c;
-  x86;
-  mips;
+  enable = x86;
+  enable = mips;
 };
 
 module = {
@@ -1336,7 +1268,7 @@ module = {
   source = loader/multiboot.c;
   source = loader/i386/multiboot_mbi.c;
   extra_dist = loader/multiboot_elfxx.c;
-  x86;
+  enable = x86;
 };
 
 module = {
@@ -1349,6 +1281,7 @@ module = {
   mips = loader/mips/linux.c;
   powerpc_ieee1275 = loader/powerpc/ieee1275/linux.c;
   sparc64_ieee1275 = loader/sparc64/ieee1275/linux.c;
+  enable = nonemu;
 };
 
 module = {
@@ -1368,17 +1301,22 @@ module = {
   i386_pc = loader/xnu.c;
 
   extra_dist = loader/machoXX.c;
+  enable = i386_pc;
+  enable = x86_efi;
 };
 
 module = {
   name = appleldr;
   x86_efi = loader/efi/appleloader.c;
+  enable = x86_efi;
 };
 
 module = {
   name = chain;
   x86_efi = loader/efi/chainloader.c;
   i386_pc = loader/i386/pc/chainloader.c;
+  enable = i386_pc;
+  enable = x86_efi;
 };
 
 module = {
@@ -1412,10 +1350,12 @@ module = {
 
   mips_yeeloong = mmap/mmap.c;
   mips_yeeloong = mmap/mips/yeeloong/uppermem.c;
+
+  enable = x86;
+  enable = mips_yeeloong;
 };
 
 module = {
-  common;
   name = normal;
   source = normal/main.c;
   source = normal/cmdline.c;
@@ -1454,55 +1394,46 @@ module = {
 };
 
 module = {
-  common;
   name = part_acorn;
   source = partmap/acorn.c;
 };
 
 module = {
-  common;
   name = part_amiga;
   source = partmap/amiga.c;
 };
 
 module = {
-  common;
   name = part_apple;
   source = partmap/apple.c;
 };
 
 module = {
-  common;
   name = part_gpt;
   source = partmap/gpt.c;
 };
 
 module = {
-  common;
   name = part_msdos;
   source = partmap/msdos.c;
 };
 
 module = {
-  common;
   name = part_sun;
   source = partmap/sun.c;
 };
 
 module = {
-  common;
   name = part_bsd;
   source = partmap/bsdlabel.c;
 };
 
 module = {
-  common;
   name = part_sunpc;
   source = partmap/sunpc.c;
 };
 
 module = {
-  common;
   name = msdospart;
   source = parttool/msdospart.c;
 };
@@ -1510,26 +1441,25 @@ module = {
 module = {
   name = at_keyboard;
   source = term/at_keyboard.c;
-  x86;
+  enable = x86;
 };
 
 module = {
   name = gfxterm;
   source = term/gfxterm.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
+  enable = emu;
+  enable = x86;
+  enable = sparc64;
+  enable = powerpc;
 };
 
 module = {
   name = serial;
   source = term/serial.c;
-  i386;
+  enable = i386;
 };
 
 module = {
-  common;
   name = terminfo;
   source = term/terminfo.c;
   source = term/tparm.c;
@@ -1538,87 +1468,88 @@ module = {
 module = {
   name = usb_keyboard;
   source = term/usb_keyboard.c;
-  i386_pc;
-  mips_yeeloong;
+  enable = i386_pc;
+  enable = mips_yeeloong;
 };
 
 module = {
   name = vga;
   i386_pc = video/i386/pc/vga.c;
+  enable = i386_pc;
 };
 
 module = {
   name = vga_text;
   x86 = term/i386/pc/vga_text.c;
   x86 = term/i386/vga_common.c;
+  enable = x86;
 };
 
 module = {
   name = video_cirrus;
   i386 = video/cirrus.c;
+  enable = i386;
 };
 
 module = {
   name = video_bochs;
   i386 = video/bochs.c;
+  enable = i386;
 };
 
 module = {
   name = functional_test;
   source = tests/lib/functional_test.c;
   source = tests/lib/test.c;
-  common;
 };
 
 module = {
   name = example_functional_test;
   source = tests/example_functional_test.c;
   cflags = -Wno-format;
-  common;
 };
 
 module = {
   name = bitmap;
   source = video/bitmap.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
+  enable = emu;
+  enable = x86;
+  enable = sparc64;
+  enable = powerpc;
 };
 
 module = {
   name = bitmap_scale;
   source = video/bitmap_scale.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
+  enable = emu;
+  enable = x86;
+  enable = sparc64;
+  enable = powerpc;
 };
 
 module = {
   name = efi_gop;
   x86_efi = video/efi_gop.c;
+  enable = x86_efi;
 };
 
 module = {
   name = efi_uga;
   x86_efi = video/efi_uga.c;
+  enable = x86_efi;
 };
 
 module = {
-  common;
   name = jpeg;
   source = video/readers/jpeg.c;
 };
 
 module = {
-  common;
   name = png;
   source = video/readers/png.c;
 };
 
 module = {
-  common;
   name = tga;
   source = video/readers/tga.c;
 };
@@ -1626,6 +1557,7 @@ module = {
 module = {
   name = vbe;
   i386_pc = video/i386/pc/vbe.c;
+  enable = i386_pc;
 };
 
 module = {
@@ -1634,37 +1566,36 @@ module = {
   source = video/fb/fbblit.c;
   source = video/fb/fbfill.c;
   source = video/fb/fbutil.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
+  enable = emu;
+  enable = x86;
+  enable = sparc64;
+  enable = powerpc;
 };
 
 module = {
   name = video;
   source = video/video.c;
-  emu;
-  x86;
-  sparc64;
-  powerpc;
+  enable = emu;
+  enable = x86;
+  enable = sparc64;
+  enable = powerpc;
 };
 
 module = {
   name = ieee1275_fb;
   source = video/ieee1275.c;
-  powerpc;
-  sparc64;
+  enable = powerpc;
+  enable = sparc64;
 };
 
 module = {
   name = sdl;
   source = video/emu/sdl.c;
-  enable = COND_GRUB_EMU_SDL;
-  emu;
+  condition = COND_GRUB_EMU_SDL;
+  enable = emu;
 };
 
 module = {
   name = datehook;
   source = hook/datehook.c;
-  common;
 };
index c8ce44cbe4e1b0aabeee8387c3f57b7ec8af3216..23d7d14cd0aedec62b4be8284234bcba9ed724c3 100644 (file)
@@ -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;
 };