/usr/share/menu/blend-menu is in blends-common 0.6.16.4ubuntu2.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 | #!/bin/bash
# Script to handle menu profiles for Debian Pure Blends subsystem, installed
# by your system administrator via blends-common package.
#
# It prints on STDOUT Debian menu entries for user
CONFBASE=${CONFBASE:-/etc/blends}
# read generic Blends conf ... in case it exists
# Since menu 2.1.39 triggers are used to run update-menus for every change
# in /usr/{lib,share}/menu - which fails finding ${CONFBASE}/blends.conf in
# case you are installing blends-common the first time. I do not regard this
# as a reasonable behaviour because it is a real performance loss and
# obviousely error prone (for instance in case of blends-common (see #484167)
# but we have to deal with this somehow
if [ -s "${CONFBASE}/blends.conf" ] ; then
. ${CONFBASE}/blends.conf
else
exit 0
fi
BLENDUSER=`whoami`
tasksdir=/usr/share/blends/tasks
# it has to be run only by unprivileged users via update-menus
test "${BLENDUSER}" == "root" && exit 0
# Upper case the first letter of a string to have a nicer menu
NameToUpper() {
if [ $# -ne 1 ] ; then
RET=64 # EX_USAGE
return ${RET}
fi
echo $1 | perl -ne 'print "\u\L$_";'
return 0
}
# Obtain title from HTML page for menu hints
GetHTMLTitle () {
if [ $# -ne 1 ] ; then
RET=64 # EX_USAGE
return ${RET}
fi
perl -ne 'while (<>) {chomp; $all.="$_ ";}
($title) = ($all =~ /.*\<title\>(.*)\<\/title\>.*/i);
$title =~ s/\s+/ /g ;
print $title ; exit 0;' $1
return 0
}
# Obtain title (= first line) from text file for menu hints
GetTxtTitle () {
if [ $# -ne 1 ] ; then
RET=64 # EX_USAGE
return ${RET}
fi
head -1 $1 | sed -e "s/[[:space:]]\+/ /g" -e "s/^[[:space:]]*\(.*\)[[:space:]]*$/\1/"
return 0
}
# Strip Blend name from metapackage name
# FIXME: the Blend name does not necessarily match the metapackage
# prefix. Example: education-* packages of Debian Edu
# Proposed fix: Read Blend name from config file
GetTaskNameFromPackage () {
if [ $# -ne 2 ] ; then
RET=64 # EX_USAGE
return ${RET}
fi
BLEND=$1 # Blend name
PKG=$2 # metapackage name
echo $PKG | sed "s/^${BLEND}-//"
return 0
}
# Obtain task title which has to be defined in the metapackage control templates
GetTaskTitle () {
if [ $# -ne 1 ] ; then
RET=64 # EX_USAGE
return ${RET}
fi
PKG=$1 # metapackage name
cat "$tasksdir"/"$BLEND"/`GetTaskNameFromPackage "$BLEND" "$PKG"`
return 0
}
getMenuEntriesFromDependencies() {
RET=""
if [ $# -ne 1 ] ; then
RET=64 # EX_USAGE
return ${RET}
fi
PKG="$BLEND"-$1
TASK=`GetTaskTitle $PKG`
SECTION=`NameToUpper "$BLEND"`/`NameToUpper "$TASK"`
# find the list of Depends / Recommends / Suggests
DepPkgs=`dpkg --status "$PKG" | \
sed -e '/^Description/,$d' -e '/^Conffiles/,$d' | \
grep -v ^[A-CE-QT-Z] | \
grep -v ^S[eot] | \
sed -e "s/([^)]*)//" \
-e "s/,* *${BLEND}-config//" \
-e "s/^[^:]*: *//" \
-e "s/, */\\n/g" | \
sort | uniq`
# check whether Blend maintainer provided menu override different from
# package maintainers menu file
# FIXME: This is outdated! The concept of menu files named like the
# metapackage is stopped in favour of single menu files named like
# the dependant package. The rationale is that you can get more
# fine grained replacements.
blendmenufile=""
if [ -s "$HOME"/.menu/"$PKG" ] ; then
blendmenufile="$HOME"/.menu/"$PKG"
elif [ -s /etc/blends/"$BLEND"/menu/"$PKG" ] ; then
blendmenufile=/etc/blends/"$BLEND"/menu/"$PKG"
elif [ -s /usr/lib/blends/"$BLEND"/menu/"$PKG" ] ; then
blendmenufile=/usr/lib/blends/"$BLEND"/menu/"$PKG"
elif [ -s /usr/share/blends/"$BLEND"/menu/"$PKG" ] ; then
blendmenufile=/usr/share/blends/"$BLEND"/menu/"$PKG"
fi
for pkg in $DepPkgs ; do
# if Blend maintainer provided override just continue
[ ! -z "$blendmenufile" ] && grep -q -i "?package($pkg)" "$blendmenufile" && continue
# check for documentation text of Blend maintainer which should
# be prefered over package maintainers menu
docfile=""
if [ -s /usr/share/doc/"$PKG"/"$pkg".html ] ; then
docfile=/usr/share/doc/"$PKG"/"$pkg".html
elif [ -s /usr/share/doc/"$PKG"/"$pkg".txt ] ; then
docfile=/usr/share/doc/"$PKG"/"$pkg".txt
elif [ -s /usr/share/doc/"$PKG"/"$pkg" ] ; then
docfile=/usr/share/doc/"$PKG"/"$pkg"
fi
# if Blend maintainer provides documentation view this as menu entry ...
if [ ! -z "$docfile" -a -s "$docfile" ] ; then
hint=""
if file "$docfile" | grep -q HTML ; then
senspager=sensible-browser
hint=`GetHTMLTitle "$docfile"`
else
senspager=sensible-pager
hint=`GetTxtTitle "$docfile"`
fi
if [ ! -z "$hint" ] ; then
hint="hints=\""$hint"\""
fi
# Force menu-1 entry in case before this was menu-2 used
cat <<EOT
!C menu-1
?package($pkg): needs="text" \\
section="$SECTION" \\
title="`NameToUpper "$pkg"`" $hint \\
command="$senspager $docfile"
EOT
fi
# search for a menu file with the following priority
# ${HOME}/.menu, /etc/menu, /usr/share/blends/${BLEND}/menu, /usr/share/menu, /usr/lib/menu
pkgmenufile=""
donotchange=1
if [ -s "$HOME"/.menu/"$pkg" ] ; then
pkgmenufile="$HOME"/.menu/"$pkg"
elif [ -s /etc/menu/"$pkg" ] ; then
pkgmenufile=/etc/menu/"$pkg"
elif [ -s /usr/share/blends/"$BLEND"/menu/"$pkg" ] ; then
pkgmenufile=/usr/share/blends/"$BLEND"/menu/"$pkg"
donotchange=0
elif [ -s /usr/share/menu/"$pkg" ] ; then
pkgmenufile=/usr/share/menu/"$pkg"
elif [ -s /usr/lib/menu/"$pkg" ] ; then
pkgmenufile=/usr/lib/menu/"$pkg"
fi
if [ ! -z "$pkgmenufile" ] ; then
# Force menu-1 entry in case before this was menu-2 used
## if ! grep -q -c '^!C' $pkgmenufile ; then
echo '!C menu-1'
## fi
if [ $donotchange -eq 1 ] ; then
# the 2. and 3. -e - expression tries to fix missing '"' around the entries
sed -e "/^[[:space:]]*$/d" \
-e 's?\([ :][^=^ ]*=\) *\([^"^=]*\)\( [^=]\+=\)?\1"\2"\3?g' \
-e 's?\([ :][^=^ ]*=\) *\([^"^=]*\)\( [^=]\+=\)?\1"\2"\3?g' \
-e 's?\( [^=]\+=\) *\([^"^=]\+[^"^\]\)$?\1"\2"?' \
-e "s?\(section\)[[:space:]]*=[[:space:]]*\"*[^\"\\]*\"*?\1=\"$SECTION\"?" $pkgmenufile
else
# strip possible comments
grep -v "^[[:space:]]*#" $pkgmenufile
fi
fi
# HACK: Add blank line which helps in case of missing newlines
echo
done
[ -s "$blendmenufile" ] && cat "$blendmenufile"
}
ALLBLENDS=`getBlendList`
for BLEND in ${ALLBLENDS}; do
# read per Blend conf
test -f ${CONFBASE}/${BLEND}/${BLEND}.conf && \
. ${CONFBASE}/${BLEND}/${BLEND}.conf
if [ -d "$tasksdir"/"$BLEND" ] ; then
for PKG in `ls "$tasksdir"/"$BLEND"` ; do
getMenuEntriesFromDependencies "$PKG"
done
fi
# # print on STDOUT menu generic entries if user belongs to Blend
# checkUserInBlend ${BLEND} ${BLENDUSER} && \
# test -d ${CONFBASE}/${BLEND}/menu/ && \
# find ${CONFBASE}/${BLEND}/menu/ -maxdepth 1 -mindepth 1 -type f \
# -exec cat {} \;
#
# # and role specific menu entries
# for ROLE in `getUserRoles ${BLEND} ${BLENDUSER}`; do
# test -d ${CONFBASE}/${BLEND}/menu/${ROLE} &&
# find ${CONFBASE}/${BLEND}/menu/${ROLE} -maxdepth 1 -mindepth 1 \
# -type f -exec cat {} \;
# done
done
|