diff --git a/etc/defaults/rc.conf b/etc/defaults/rc.conf index 43a213b242ec..9d99725e2347 100644 --- a/etc/defaults/rc.conf +++ b/etc/defaults/rc.conf @@ -125,6 +125,7 @@ per_user_tmp=NO # per-user /tmp directories per_user_tmp_dir="/private/tmp" # real storage for /tmp clear_tmp=YES # clear /tmp after reboot update_motd=YES # updates /etc/motd +update_motd_release=NO motd_release_tag="" # release info in /etc/motd dmesg=YES dmesg_flags="" # write /var/run/dmesg.boot accounting=NO # uses /var/account/acct newsyslog=NO newsyslog_flags="" # trim log files diff --git a/etc/rc.d/motd b/etc/rc.d/motd index 818d811c431c..56e837208b82 100755 --- a/etc/rc.d/motd +++ b/etc/rc.d/motd @@ -16,7 +16,7 @@ stop_cmd=":" motd_start() { - # Update kernel info in /etc/motd + # Update kernel and release info in /etc/motd # Must be done *before* interactive logins are possible # to prevent possible race conditions. # @@ -27,7 +27,16 @@ motd_start() ( umask 022 T=/etc/_motd sysctl -n kern.version | while read i; do echo $i; break; done > $T - sed '1{/^NetBSD.*/{d;};};' < /etc/motd >> $T + if checkyesno update_motd_release; then + local t="${motd_release_tag}" + sed -En '1{/^NetBSD/{s/^/'"$t"'/;h;d;};q;} + /^ *Build ID */{s//(/;s/$/)/;H;g;y/\n/ /;p;q;} + ${g;p;}' < /etc/release >> $T + sed -E '1,2{/^'"${t+(${t})?}"'NetBSD/{d;};};' \ + < /etc/motd >> $T + else + sed '1{/^NetBSD.*/{d;};};' < /etc/motd >> $T + fi cmp -s $T /etc/motd || cp $T /etc/motd rm -f $T )