RPM fixes
This commit is contained in:
parent
004fa78dab
commit
4f0c19deea
6 changed files with 242 additions and 8 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -2,6 +2,7 @@
|
||||||
API_KEYS.txt
|
API_KEYS.txt
|
||||||
*.deb
|
*.deb
|
||||||
*.rpm
|
*.rpm
|
||||||
|
*.snap
|
||||||
*.AppImage
|
*.AppImage
|
||||||
*.zip
|
*.zip
|
||||||
thorium_mini_installer.exe
|
thorium_mini_installer.exe
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
START "" "%cd%\BIN\113.0.5672.134\thorium_shell.exe" --data-path="%~dp0%\USER_DATA\thorium_shell" --allow-outdated-plugins --disable-logging --disable-breakpad --enable-experimental-web-platform-features --new-canvas-2d-api
|
START "" "%cd%\BIN\114.0.5735.134\thorium_shell.exe" --data-path="%~dp0%\USER_DATA\thorium_shell" --allow-outdated-plugins --disable-logging --disable-breakpad --enable-experimental-web-platform-features --new-canvas-2d-api
|
||||||
|
|
202
src/chrome/installer/linux/common/rpm.include
Normal file
202
src/chrome/installer/linux/common/rpm.include
Normal file
|
@ -0,0 +1,202 @@
|
||||||
|
@@include@@repo_variables.include
|
||||||
|
|
||||||
|
# Install the repository signing key (see also:
|
||||||
|
# https://www.google.com/linuxrepositories/)
|
||||||
|
install_rpm_key() {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
determine_rpm_package_manager() {
|
||||||
|
local RELEASE
|
||||||
|
|
||||||
|
# Modern method using os-release(5)
|
||||||
|
if [ -f "/etc/os-release" ]; then
|
||||||
|
RELEASE=$(. "/etc/os-release"; echo "$ID")
|
||||||
|
case $RELEASE in
|
||||||
|
"fedora"|"rhel"|"centos"|"amzn"|"mageia"|"openmandriva")
|
||||||
|
PACKAGEMANAGERS=(yum)
|
||||||
|
;;
|
||||||
|
"suse"|"sles"|"sled"|"opensuse"|"opensuse-leap"|"opensuse-tumbleweed")
|
||||||
|
PACKAGEMANAGERS=(zypp)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$PACKAGEMANAGERS" ]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Fallback method using lsb_release(1)
|
||||||
|
LSB_RELEASE="$(command -v lsb_release 2> /dev/null)"
|
||||||
|
if [ -x "$LSB_RELEASE" ]; then
|
||||||
|
RELEASE=$(lsb_release -i 2> /dev/null | sed 's/:\t/:/' | cut -d ':' -f 2-)
|
||||||
|
case $RELEASE in
|
||||||
|
"Fedora"|"Amazon"|"Mageia"|"OpenMandrivaLinux")
|
||||||
|
PACKAGEMANAGERS=(yum)
|
||||||
|
;;
|
||||||
|
"SUSE LINUX"|"openSUSE")
|
||||||
|
PACKAGEMANAGERS=(zypp)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$PACKAGEMANAGERS" ]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Fallback methods that are probably unnecessary on modern systems.
|
||||||
|
if [ -f "/etc/fedora-release" ] || [ -f "/etc/redhat-release" ]; then
|
||||||
|
PACKAGEMANAGERS=(yum)
|
||||||
|
elif [ -f "/etc/system-release" ] && grep -Fq "Amazon Linux" "/etc/system-release"; then
|
||||||
|
PACKAGEMANAGERS=(yum)
|
||||||
|
elif [ -f "/etc/SuSE-release" ]; then
|
||||||
|
PACKAGEMANAGERS=(zypp)
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
DEFAULT_ARCH="@@ARCHITECTURE@@"
|
||||||
|
YUM_REPO_FILE="/etc/yum.repos.d/@@PACKAGE@@.repo"
|
||||||
|
ZYPPER_REPO_FILE="/etc/zypp/repos.d/@@PACKAGE@@.repo"
|
||||||
|
|
||||||
|
install_yum() {
|
||||||
|
install_rpm_key
|
||||||
|
|
||||||
|
if [ ! "$REPOCONFIG" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d "/etc/yum.repos.d" ]; then
|
||||||
|
cat > "$YUM_REPO_FILE" << REPOCONTENT
|
||||||
|
[@@PACKAGE@@]
|
||||||
|
name=@@PACKAGE@@
|
||||||
|
baseurl=$REPOCONFIG/$DEFAULT_ARCH
|
||||||
|
enabled=1
|
||||||
|
gpgcheck=1
|
||||||
|
gpgkey=https://dl.google.com/linux/linux_signing_key.pub
|
||||||
|
REPOCONTENT
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
install_zypp() {
|
||||||
|
if [ ! "$REPOCONFIG" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Ideally, we would run: zypper addrepo -t YUM -f \
|
||||||
|
# "$REPOCONFIG/$DEFAULT_ARCH" "@@PACKAGE@@"
|
||||||
|
# but that does not work when zypper is running.
|
||||||
|
if [ -d "/etc/zypp/repos.d" ]; then
|
||||||
|
cat > "$ZYPPER_REPO_FILE" << REPOCONTENT
|
||||||
|
[@@PACKAGE@@]
|
||||||
|
name=@@PACKAGE@@
|
||||||
|
enabled=1
|
||||||
|
autorefresh=1
|
||||||
|
baseurl=$REPOCONFIG/$DEFAULT_ARCH
|
||||||
|
gpgcheck=1
|
||||||
|
gpgkey=https://dl.google.com/linux/linux_signing_key.pub
|
||||||
|
type=rpm-md
|
||||||
|
keeppackages=0
|
||||||
|
REPOCONTENT
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Check if the automatic repository configuration is done, so we know when to
|
||||||
|
# stop trying.
|
||||||
|
verify_install() {
|
||||||
|
# It's probably enough to see that the repo configs have been created. If they
|
||||||
|
# aren't configured properly, update_bad_repo should catch that when it's run.
|
||||||
|
case $1 in
|
||||||
|
"yum")
|
||||||
|
[ -f "$YUM_REPO_FILE" ]
|
||||||
|
;;
|
||||||
|
"zypp")
|
||||||
|
[ -f "$ZYPPER_REPO_FILE" ]
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# Update the Google repository if it's not set correctly.
|
||||||
|
update_bad_repo() {
|
||||||
|
if [ ! "$REPOCONFIG" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
determine_rpm_package_manager
|
||||||
|
|
||||||
|
for PACKAGEMANAGER in ${PACKAGEMANAGERS[*]}
|
||||||
|
do
|
||||||
|
case $PACKAGEMANAGER in
|
||||||
|
"yum")
|
||||||
|
update_repo_file "$YUM_REPO_FILE"
|
||||||
|
;;
|
||||||
|
"zypp")
|
||||||
|
update_repo_file "$ZYPPER_REPO_FILE"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
update_repo_file() {
|
||||||
|
REPO_FILE="$1"
|
||||||
|
|
||||||
|
# Don't do anything if the file isn't there, since that probably means the
|
||||||
|
# user disabled it.
|
||||||
|
if [ ! -r "$REPO_FILE" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the correct repository configuration is in there.
|
||||||
|
REPOMATCH=$(grep "^baseurl=$REPOCONFIG/$DEFAULT_ARCH" "$REPO_FILE" \
|
||||||
|
2>/dev/null)
|
||||||
|
# If it's there, nothing to do
|
||||||
|
if [ "$REPOMATCH" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if it's there but disabled by commenting out (as opposed to using the
|
||||||
|
# 'enabled' setting).
|
||||||
|
MATCH_DISABLED=$(grep "^[[:space:]]*#.*baseurl=$REPOCONFIG/$DEFAULT_ARCH" \
|
||||||
|
"$REPO_FILE" 2>/dev/null)
|
||||||
|
if [ "$MATCH_DISABLED" ]; then
|
||||||
|
# It's OK for it to be disabled, as long as nothing bogus is enabled in its
|
||||||
|
# place.
|
||||||
|
ACTIVECONFIGS=$(grep "^baseurl=.*" "$REPO_FILE" 2>/dev/null)
|
||||||
|
if [ ! "$ACTIVECONFIGS" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# If we get here, the correct repository wasn't found, or something else is
|
||||||
|
# active, so fix it. This assumes there is a 'baseurl' setting, but if not,
|
||||||
|
# then that's just another way of disabling, so we won't try to add it.
|
||||||
|
sed -i -e "s,^baseurl=.*,baseurl=$REPOCONFIG/$DEFAULT_ARCH," "$REPO_FILE"
|
||||||
|
}
|
||||||
|
|
||||||
|
# We only remove the repository configuration during a purge. Since RPM has
|
||||||
|
# no equivalent to dpkg --purge, the code below is actually never used. We
|
||||||
|
# keep it only for reference purposes, should we ever need it.
|
||||||
|
#
|
||||||
|
#remove_yum() {
|
||||||
|
# rm -f "$YUM_REPO_FILE"
|
||||||
|
#}
|
||||||
|
#
|
||||||
|
#remove_zypp() {
|
||||||
|
# # Ideally, we would run: zypper removerepo "@@PACKAGE@@"
|
||||||
|
# # but that does not work when zypper is running.
|
||||||
|
# rm -f /etc/zypp/repos.d/@@PACKAGE@@.repo
|
||||||
|
#}
|
||||||
|
|
||||||
|
DEFAULT_ARCH="@@ARCHITECTURE@@"
|
||||||
|
|
||||||
|
get_lib_dir() {
|
||||||
|
if [ "$DEFAULT_ARCH" = "i386" ] || [ "$DEFAULT_ARCH" = "armhf" ] || \
|
||||||
|
[ "$DEFAULT_ARCH" = "mipsel" ]; then
|
||||||
|
LIBDIR=lib
|
||||||
|
elif [ "$DEFAULT_ARCH" = "x86_64" ] || [ "$DEFAULT_ARCH" = "aarch64" ] || \
|
||||||
|
[ "$DEFAULT_ARCH" = "mips64el" ]; then
|
||||||
|
LIBDIR=lib64
|
||||||
|
else
|
||||||
|
echo Unknown CPU Architecture: "$DEFAULT_ARCH"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
}
|
27
src/chrome/installer/linux/common/rpmrepo.cron
Executable file
27
src/chrome/installer/linux/common/rpmrepo.cron
Executable file
|
@ -0,0 +1,27 @@
|
||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# Copyright 2009 The Chromium Authors
|
||||||
|
# Use of this source code is governed by a BSD-style license that can be
|
||||||
|
# found in the LICENSE file.
|
||||||
|
#
|
||||||
|
# This script is part of the @@PACKAGE@@ package.
|
||||||
|
#
|
||||||
|
# It creates the repository configuration file for package updates, since
|
||||||
|
# we cannot do this during the @@PACKAGE@@ installation since the repository
|
||||||
|
# is locked.
|
||||||
|
#
|
||||||
|
# This functionality can be controlled by creating the $DEFAULTS_FILE and
|
||||||
|
# setting "repo_add_once" to "true" or "false" as desired. An empty
|
||||||
|
# $DEFAULTS_FILE is the same as setting the value to "false".
|
||||||
|
|
||||||
|
@@include@@../common/variables.include
|
||||||
|
|
||||||
|
@@include@@rpm.include
|
||||||
|
|
||||||
|
## MAIN ##
|
||||||
|
if [ -r "$DEFAULTS_FILE" ]; then
|
||||||
|
. "$DEFAULTS_FILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
install_rpm_key
|
||||||
|
|
|
@ -41,6 +41,16 @@ prefix : /opt
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
%build
|
%build
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
# Ignore libffmpeg.so
|
||||||
|
#------------------------------------------------------------------------------
|
||||||
|
%global _privatelibs libffmpeg.so
|
||||||
|
%global __provides_exclude ^(%{_privatelibs})$
|
||||||
|
%global __requires_exclude ^(%{_privatelibs})$
|
||||||
|
%global __requires_exclude ^libffmpeg\\((autotest|basetest)
|
||||||
|
|
||||||
|
# %define __requires_exclude libffmpeg.so
|
||||||
|
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
# Installation rule - how to install it (note that it
|
# Installation rule - how to install it (note that it
|
||||||
# gets installed into a temp directory given by $RPM_BUILD_ROOT)
|
# gets installed into a temp directory given by $RPM_BUILD_ROOT)
|
||||||
|
@ -167,9 +177,6 @@ case $CHANNEL in
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
%{_sbindir}/update-alternatives --install /usr/bin/@@PACKAGE_ORIG@@ \
|
|
||||||
@@PACKAGE_ORIG@@ /usr/bin/@@USR_BIN_SYMLINK_NAME@@ $PRIORITY
|
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
|
||||||
|
|
||||||
|
@ -194,9 +201,6 @@ if [ "$mode" = "uninstall" ]; then
|
||||||
@@include@@../common/prerm.include
|
@@include@@../common/prerm.include
|
||||||
remove_nss_symlinks
|
remove_nss_symlinks
|
||||||
remove_udev_symlinks
|
remove_udev_symlinks
|
||||||
|
|
||||||
%{_sbindir}/update-alternatives --remove @@PACKAGE_ORIG@@ \
|
|
||||||
/usr/bin/@@USR_BIN_SYMLINK_NAME@@
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# On Debian we only remove when we purge. However, RPM has no equivalent to
|
# On Debian we only remove when we purge. However, RPM has no equivalent to
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 4019eecf9d31d19c5b6dbf58383dfbd4b25c9522
|
Subproject commit 63f6acade5674ab97062ee677a8a6ebd725ae1e2
|
Loading…
Reference in a new issue