Hooks and modules have a .sh extension
authorVictor Lowther <victor.lowther@gmail.com>
Fri, 20 Feb 2009 17:24:18 +0000 (09:24 -0800)
committerDave Jones <davej@redhat.com>
Mon, 23 Feb 2009 18:22:01 +0000 (13:22 -0500)
This makes it trivial to filter out temporary files, editor backups,
package management leftovers, etc.  Thanks, Kay for the idea.

16 files changed:
Makefile
README
dracut
hooks/cryptroot.sh [moved from hooks/cryptroot with 100% similarity]
hooks/resume.sh [moved from hooks/resume with 100% similarity]
hooks/selinux-loadpolicy.sh [moved from hooks/selinux-loadpolicy with 100% similarity]
init
modules/00dash.sh [moved from modules/00dash with 100% similarity]
modules/10redhat-i18n.sh [moved from modules/10redhat-i18n with 100% similarity]
modules/90crypt.sh [moved from modules/90crypt with 58% similarity]
modules/90kernel-modules.sh [moved from modules/90kernel-modules with 100% similarity]
modules/90lvm.sh [moved from modules/90lvm with 100% similarity]
modules/95debug.sh [moved from modules/95debug with 100% similarity]
modules/95terminfo.sh [moved from modules/95terminfo with 100% similarity]
modules/95udev-rules.sh [moved from modules/95udev-rules with 100% similarity]
modules/99base.sh [moved from modules/99base with 63% similarity]

index 70d6782..dbc2a7d 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -12,8 +12,8 @@ install:
        install -m 0755 dracut-functions $(DESTDIR)/usr/libexec/dracut/functions
        mkdir $(DESTDIR)/usr/libexec/dracut/rules.d
        for rule in rules.d/*.rules ; do install -m 0644 $$rule $(DESTDIR)/usr/libexec/dracut ; done
-       for hook in hooks/* ; do install -m 0755 $$hook $(DESTDIR)/usr/libexec/dracut ; done
-       for module in modules/*; do install -m 0755 $$module $(DESTDIR)/usr/libexec/dracut ; done
+       for hook in hooks/*.sh ; do install -m 0755 $$hook $(DESTDIR)/usr/libexec/dracut ; done
+       for module in modules/*.sh; do install -m 0755 $$module $(DESTDIR)/usr/libexec/dracut ; done
 clean:
        rm -f *~
 
diff --git a/README b/README
index abc282a..1c377b4 100644 (file)
--- a/README
+++ b/README
@@ -37,6 +37,7 @@ Some general rules for writing modules:
  * Generator modules should have a two digit numeric prefix -- they run in
    ascending sort order. Anything in the 90-99 range is stuff that dracut
    relies on, so try not to break those hooks.
+ * Generator modules and hooks must have a .sh extension. 
 
 Also, there is an attempt to keep things as distribution-agnostic as
 possible.  Every distribution has their own tool here and it's not
diff --git a/dracut b/dracut
index 1378268..c00944e 100755 (executable)
--- a/dracut
+++ b/dracut
@@ -44,7 +44,7 @@ hookdirs="pre-udev pre-mount pre-pivot"
 initdir=$(mktemp -d -t initramfs.XXXXXX)
 trap 'rm -rf "$initdir"' 0 # clean up after ourselves no matter how we die.
 
-export initdir hookdirs rulesdir dsrc dracutmodules kmodules
+export initdir hookdirs rulesdir dsrc dracutmodules modules
 
 # Create some directory structure first
 for d in bin sbin usr/bin usr/sbin usr/lib etc proc sys sysroot dev/pts; do 
@@ -52,8 +52,8 @@ for d in bin sbin usr/bin usr/sbin usr/lib etc proc sys sysroot dev/pts; do
 done
 
 # source all our modules
-for f in "$dsrc/modules"/*[^~]; do
-    mod=${f##*/}; mod=${mod#[0-9][0-9]}
+for f in "$dsrc/modules"/*.sh; do
+    mod=${f##*/}; mod=${mod#[0-9][0-9]}; mod=${mod%.sh}
     if [[ $dracutmodules = all ]] || strstr "$dracutmodules" "$mod"; then 
        [[ -x $f ]] && . "$f"
     fi
similarity index 100%
rename from hooks/cryptroot
rename to hooks/cryptroot.sh
similarity index 100%
rename from hooks/resume
rename to hooks/resume.sh
diff --git a/init b/init
index ad6c06f..06689a6 100755 (executable)
--- a/init
+++ b/init
@@ -24,7 +24,7 @@ getarg() {
 source_all() {
     local f
     [ "$1" ] && [  -d "/$1" ] || return
-    for f in "/$1"/*; do [ -f "$f" ] && . "$f"; done
+    for f in "/$1"/*.sh; do [ -f "$f" ] && . "$f"; done
 }
 
 echo "Starting initrd..."
similarity index 100%
rename from modules/00dash
rename to modules/00dash.sh
similarity index 58%
rename from modules/90crypt
rename to modules/90crypt.sh
index 66d7e70..9793a4f 100755 (executable)
@@ -1,4 +1,4 @@
 #!/bin/bash
 inst cryptsetup
 inst_rules "$dsrc/rules.d/63-luks.rules"
-inst_hook pre-mount 50 "$dsrc/hooks/cryptroot"
\ No newline at end of file
+inst_hook pre-mount 50 "$dsrc/hooks/cryptroot.sh"
\ No newline at end of file
similarity index 100%
rename from modules/90lvm
rename to modules/90lvm.sh
similarity index 100%
rename from modules/95debug
rename to modules/95debug.sh
similarity index 100%
rename from modules/95terminfo
rename to modules/95terminfo.sh
similarity index 100%
rename from modules/95udev-rules
rename to modules/95udev-rules.sh
similarity index 63%
rename from modules/99base
rename to modules/99base.sh
index 4963beb..1d9f86e 100755 (executable)
@@ -3,6 +3,6 @@ dracut_install mount mknod mkdir modprobe pidof sleep chroot echo sed sh ls
 # install our scripts and hooks
 inst "$initfile" "/init"
 inst "$switchroot" "/sbin/switch_root"
-inst_hook pre-pivot 50 "$dsrc/hooks/selinux-loadpolicy"
-inst_hook pre-mount 99 "$dsrc/hooks/resume"
+inst_hook pre-pivot 50 "$dsrc/hooks/selinux-loadpolicy.sh"
+inst_hook pre-mount 99 "$dsrc/hooks/resume.sh"