132 lines
5.1 KiB
Diff
132 lines
5.1 KiB
Diff
|
From 06a1d0769055f437c938edd40bd9fbd622475864 Mon Sep 17 00:00:00 2001
|
||
|
From: =?UTF-8?q?Ville=20Skytt=C3=A4?= <ville.skytta@iki.fi>
|
||
|
Date: Mon, 28 Mar 2016 12:09:06 +0300
|
||
|
Subject: [PATCH] dracut-init.sh: Simplify udev rule grepping
|
||
|
|
||
|
---
|
||
|
dracut-init.sh | 102 ++++++++++++++++++++++++++-------------------------------
|
||
|
1 file changed, 46 insertions(+), 56 deletions(-)
|
||
|
|
||
|
diff --git a/dracut-init.sh b/dracut-init.sh
|
||
|
index a67aca2..b176421 100644
|
||
|
--- a/dracut-init.sh
|
||
|
+++ b/dracut-init.sh
|
||
|
@@ -275,71 +275,61 @@ rev_lib_symlinks() {
|
||
|
inst_rule_programs() {
|
||
|
local _prog _bin
|
||
|
|
||
|
- if grep -qE 'PROGRAM==?"[^ "]+' "$1"; then
|
||
|
- for _prog in $(grep -E 'PROGRAM==?"[^ "]+' "$1" | sed -r 's/.*PROGRAM==?"([^ "]+).*/\1/'); do
|
||
|
- _bin=""
|
||
|
- if [ -x ${udevdir}/$_prog ]; then
|
||
|
- _bin=${udevdir}/$_prog
|
||
|
- elif [[ "${_prog/\$env\{/}" == "$_prog" ]]; then
|
||
|
- _bin=$(find_binary "$_prog") || {
|
||
|
- dinfo "Skipping program $_prog using in udev rule ${1##*/} as it cannot be found"
|
||
|
- continue;
|
||
|
- }
|
||
|
- fi
|
||
|
+ for _prog in $(sed -nr 's/.*PROGRAM==?"([^ "]+).*/\1/p'); do
|
||
|
+ _bin=""
|
||
|
+ if [ -x ${udevdir}/$_prog ]; then
|
||
|
+ _bin=${udevdir}/$_prog
|
||
|
+ elif [[ "${_prog/\$env\{/}" == "$_prog" ]]; then
|
||
|
+ _bin=$(find_binary "$_prog") || {
|
||
|
+ dinfo "Skipping program $_prog using in udev rule ${1##*/} as it cannot be found"
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+ fi
|
||
|
|
||
|
- [[ $_bin ]] && inst_binary "$_bin"
|
||
|
- done
|
||
|
- fi
|
||
|
- if grep -qE 'RUN[+=]=?"[^ "]+' "$1"; then
|
||
|
- for _prog in $(grep -E 'RUN[+=]=?"[^ "]+' "$1" | sed -r 's/.*RUN[+=]=?"([^ "]+).*/\1/'); do
|
||
|
- _bin=""
|
||
|
- if [ -x ${udevdir}/$_prog ]; then
|
||
|
- _bin=${udevdir}/$_prog
|
||
|
- elif [[ "${_prog/\$env\{/}" == "$_prog" ]] && [[ "${_prog}" != "/sbin/initqueue" ]]; then
|
||
|
- _bin=$(find_binary "$_prog") || {
|
||
|
- dinfo "Skipping program $_prog using in udev rule ${1##*/} as it cannot be found"
|
||
|
- continue;
|
||
|
- }
|
||
|
- fi
|
||
|
+ [[ $_bin ]] && inst_binary "$_bin"
|
||
|
+ done
|
||
|
+ for _prog in $(sed -nr 's/.*RUN[+=]=?"([^ "]+).*/\1/p'); do
|
||
|
+ _bin=""
|
||
|
+ if [ -x ${udevdir}/$_prog ]; then
|
||
|
+ _bin=${udevdir}/$_prog
|
||
|
+ elif [[ "${_prog/\$env\{/}" == "$_prog" ]] && [[ "${_prog}" != "/sbin/initqueue" ]]; then
|
||
|
+ _bin=$(find_binary "$_prog") || {
|
||
|
+ dinfo "Skipping program $_prog using in udev rule ${1##*/} as it cannot be found"
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+ fi
|
||
|
|
||
|
- [[ $_bin ]] && inst_binary "$_bin"
|
||
|
- done
|
||
|
- fi
|
||
|
- if grep -qE 'IMPORT\{program\}==?"[^ "]+' "$1"; then
|
||
|
- for _prog in $(grep -E 'IMPORT\{program\}==?"[^ "]+' "$1" | sed -r 's/.*IMPORT\{program\}==?"([^ "]+).*/\1/'); do
|
||
|
- _bin=""
|
||
|
- if [ -x ${udevdir}/$_prog ]; then
|
||
|
- _bin=${udevdir}/$_prog
|
||
|
- elif [[ "${_prog/\$env\{/}" == "$_prog" ]]; then
|
||
|
- _bin=$(find_binary "$_prog") || {
|
||
|
- dinfo "Skipping program $_prog using in udev rule ${1##*/} as it cannot be found"
|
||
|
- continue;
|
||
|
- }
|
||
|
- fi
|
||
|
+ [[ $_bin ]] && inst_binary "$_bin"
|
||
|
+ done
|
||
|
+ for _prog in $(sed -nr 's/.*IMPORT\{program\}==?"([^ "]+).*/\1/p'); do
|
||
|
+ _bin=""
|
||
|
+ if [ -x ${udevdir}/$_prog ]; then
|
||
|
+ _bin=${udevdir}/$_prog
|
||
|
+ elif [[ "${_prog/\$env\{/}" == "$_prog" ]]; then
|
||
|
+ _bin=$(find_binary "$_prog") || {
|
||
|
+ dinfo "Skipping program $_prog using in udev rule ${1##*/} as it cannot be found"
|
||
|
+ continue;
|
||
|
+ }
|
||
|
+ fi
|
||
|
|
||
|
- [[ $_bin ]] && dracut_install "$_bin"
|
||
|
- done
|
||
|
- fi
|
||
|
+ [[ $_bin ]] && dracut_install "$_bin"
|
||
|
+ done
|
||
|
}
|
||
|
|
||
|
# attempt to install any programs specified in a udev rule
|
||
|
inst_rule_group_owner() {
|
||
|
local i
|
||
|
|
||
|
- if grep -qE 'OWNER=?"[^ "]+' "$1"; then
|
||
|
- for i in $(grep -E 'OWNER=?"[^ "]+' "$1" | sed -r 's/.*OWNER=?"([^ "]+).*/\1/'); do
|
||
|
- if ! grep -Eq "^$i:" "$initdir/etc/passwd" 2>/dev/null; then
|
||
|
- grep -E "^$i:" /etc/passwd 2>/dev/null >> "$initdir/etc/passwd"
|
||
|
- fi
|
||
|
- done
|
||
|
- fi
|
||
|
- if grep -qE 'GROUP=?"[^ "]+' "$1"; then
|
||
|
- for i in $(grep -E 'GROUP=?"[^ "]+' "$1" | sed -r 's/.*GROUP=?"([^ "]+).*/\1/'); do
|
||
|
- if ! grep -Eq "^$i:" "$initdir/etc/group" 2>/dev/null; then
|
||
|
- grep -E "^$i:" /etc/group 2>/dev/null >> "$initdir/etc/group"
|
||
|
- fi
|
||
|
- done
|
||
|
- fi
|
||
|
+ for i in $(sed -nr 's/.*OWNER=?"([^ "]+).*/\1/p'); do
|
||
|
+ if ! grep -Eq "^$i:" "$initdir/etc/passwd" 2>/dev/null; then
|
||
|
+ grep -E "^$i:" /etc/passwd 2>/dev/null >> "$initdir/etc/passwd"
|
||
|
+ fi
|
||
|
+ done
|
||
|
+ for i in $(sed -nr 's/.*GROUP=?"([^ "]+).*/\1/p' "$1"); do
|
||
|
+ if ! grep -Eq "^$i:" "$initdir/etc/group" 2>/dev/null; then
|
||
|
+ grep -E "^$i:" /etc/group 2>/dev/null >> "$initdir/etc/group"
|
||
|
+ fi
|
||
|
+ done
|
||
|
}
|
||
|
|
||
|
inst_rule_initqueue() {
|