Merge pull request #81475 from worldofpeace/fix-wrapgapps
wrapGAppsHook: Fix #78803
This commit is contained in:
commit
add141c052
@ -9,6 +9,37 @@ find_gio_modules() {
|
|||||||
|
|
||||||
addEnvHooks "${targetOffset:?}" find_gio_modules
|
addEnvHooks "${targetOffset:?}" find_gio_modules
|
||||||
|
|
||||||
|
gappsWrapperArgsHook() {
|
||||||
|
if [ -n "$GDK_PIXBUF_MODULE_FILE" ]; then
|
||||||
|
gappsWrapperArgs+=(--set GDK_PIXBUF_MODULE_FILE "$GDK_PIXBUF_MODULE_FILE")
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$XDG_ICON_DIRS" ]; then
|
||||||
|
gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "$XDG_ICON_DIRS")
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$GSETTINGS_SCHEMAS_PATH" ]; then
|
||||||
|
gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "$GSETTINGS_SCHEMAS_PATH")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check for prefix as well
|
||||||
|
if [ -d "${prefix:?}/share" ]; then
|
||||||
|
gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "$prefix/share")
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d "$prefix/lib/gio/modules" ] && [ -n "$(ls -A "$prefix/lib/gio/modules")" ]; then
|
||||||
|
gappsWrapperArgs+=(--prefix GIO_EXTRA_MODULES : "$prefix/lib/gio/modules")
|
||||||
|
fi
|
||||||
|
|
||||||
|
for v in ${wrapPrefixVariables:-} GST_PLUGIN_SYSTEM_PATH_1_0 GI_TYPELIB_PATH GRL_PLUGIN_PATH; do
|
||||||
|
if [ -n "${!v}" ]; then
|
||||||
|
gappsWrapperArgs+=(--prefix "$v" : "${!v}")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
preFixupPhases+=" gappsWrapperArgsHook"
|
||||||
|
|
||||||
wrapGApp() {
|
wrapGApp() {
|
||||||
local program="$1"
|
local program="$1"
|
||||||
shift 1
|
shift 1
|
||||||
@ -21,44 +52,18 @@ wrapGAppsHook() {
|
|||||||
[ -z "$wrapGAppsHookHasRun" ] || return 0
|
[ -z "$wrapGAppsHookHasRun" ] || return 0
|
||||||
wrapGAppsHookHasRun=1
|
wrapGAppsHookHasRun=1
|
||||||
|
|
||||||
if [ -n "$GDK_PIXBUF_MODULE_FILE" ]; then
|
|
||||||
gappsWrapperArgs+=(--set GDK_PIXBUF_MODULE_FILE "$GDK_PIXBUF_MODULE_FILE")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$XDG_ICON_DIRS" ]; then
|
|
||||||
gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "$XDG_ICON_DIRS")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$GSETTINGS_SCHEMAS_PATH" ]; then
|
|
||||||
gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "$GSETTINGS_SCHEMAS_PATH")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -d "${prefix:?}/share" ]; then
|
|
||||||
gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "$prefix/share")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -d "$prefix/lib/gio/modules" ] && [ -n "$(ls -A "$prefix/lib/gio/modules")" ] ; then
|
|
||||||
gappsWrapperArgs+=(--prefix GIO_EXTRA_MODULES : "$prefix/lib/gio/modules")
|
|
||||||
fi
|
|
||||||
|
|
||||||
for v in ${wrapPrefixVariables:-} GST_PLUGIN_SYSTEM_PATH_1_0 GI_TYPELIB_PATH GRL_PLUGIN_PATH; do
|
|
||||||
if [ -n "${!v}" ]; then
|
|
||||||
gappsWrapperArgs+=(--prefix "$v" : "${!v}")
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
if [[ -z "${dontWrapGApps:-}" ]]; then
|
if [[ -z "${dontWrapGApps:-}" ]]; then
|
||||||
targetDirsThatExist=()
|
targetDirsThatExist=()
|
||||||
targetDirsRealPath=()
|
targetDirsRealPath=()
|
||||||
|
|
||||||
# wrap binaries
|
# wrap binaries
|
||||||
targetDirs=( "${prefix}/bin" "${prefix}/libexec" )
|
targetDirs=("${prefix}/bin" "${prefix}/libexec")
|
||||||
for targetDir in "${targetDirs[@]}"; do
|
for targetDir in "${targetDirs[@]}"; do
|
||||||
if [[ -d "${targetDir}" ]]; then
|
if [[ -d "${targetDir}" ]]; then
|
||||||
targetDirsThatExist+=("${targetDir}")
|
targetDirsThatExist+=("${targetDir}")
|
||||||
targetDirsRealPath+=("$(realpath "${targetDir}")/")
|
targetDirsRealPath+=("$(realpath "${targetDir}")/")
|
||||||
find "${targetDir}" -type f -executable -print0 \
|
find "${targetDir}" -type f -executable -print0 |
|
||||||
| while IFS= read -r -d '' file; do
|
while IFS= read -r -d '' file; do
|
||||||
echo "Wrapping program '${file}'"
|
echo "Wrapping program '${file}'"
|
||||||
wrapGApp "${file}"
|
wrapGApp "${file}"
|
||||||
done
|
done
|
||||||
@ -69,8 +74,8 @@ wrapGAppsHook() {
|
|||||||
# Note: links to binaries within targetDirs do not need
|
# Note: links to binaries within targetDirs do not need
|
||||||
# to be wrapped as the binaries have already been wrapped
|
# to be wrapped as the binaries have already been wrapped
|
||||||
if [[ ${#targetDirsThatExist[@]} -ne 0 ]]; then
|
if [[ ${#targetDirsThatExist[@]} -ne 0 ]]; then
|
||||||
find "${targetDirsThatExist[@]}" -type l -xtype f -executable -print0 \
|
find "${targetDirsThatExist[@]}" -type l -xtype f -executable -print0 |
|
||||||
| while IFS= read -r -d '' linkPath; do
|
while IFS= read -r -d '' linkPath; do
|
||||||
linkPathReal=$(realpath "${linkPath}")
|
linkPathReal=$(realpath "${linkPath}")
|
||||||
for targetPath in "${targetDirsRealPath[@]}"; do
|
for targetPath in "${targetDirsRealPath[@]}"; do
|
||||||
if [[ "$linkPathReal" == "$targetPath"* ]]; then
|
if [[ "$linkPathReal" == "$targetPath"* ]]; then
|
||||||
|
Loading…
x
Reference in New Issue
Block a user