forked from RetroPie/RetroPie-Setup
-
Notifications
You must be signed in to change notification settings - Fork 0
/
retropie_packages.sh
executable file
·86 lines (68 loc) · 2.26 KB
/
retropie_packages.sh
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
#!/usr/bin/env bash
# This file is part of The RetroPie Project
#
# The RetroPie Project is the legal property of its developers, whose names are
# too numerous to list here. Please refer to the COPYRIGHT.md file distributed with this source.
#
# See the LICENSE.md file at the top-level directory of this distribution and
# at https://raw.githubusercontent.com/RetroPie/RetroPie-Setup/master/LICENSE.md
#
__version="4.8.3"
[[ "$__debug" -eq 1 ]] && set -x
# main retropie install location
rootdir="/opt/retropie"
# if __user is set, try and install for that user, else use SUDO_USER
if [[ -n "$__user" ]]; then
user="$__user"
if ! id -u "$__user" &>/dev/null; then
echo "User $__user not exist"
exit 1
fi
else
user="$SUDO_USER"
[[ -z "$user" ]] && user="$(id -un)"
fi
home="$(eval echo ~$user)"
datadir="$home/RetroPie"
biosdir="$datadir/BIOS"
romdir="$datadir/roms"
emudir="$rootdir/emulators"
configdir="$rootdir/configs"
scriptdir="$(dirname "$0")"
scriptdir="$(cd "$scriptdir" && pwd)"
__logdir="$scriptdir/logs"
__tmpdir="$scriptdir/tmp"
__builddir="$__tmpdir/build"
__swapdir="$__tmpdir"
# check, if sudo is used
if [[ "$(id -u)" -ne 0 ]]; then
echo "Script must be run under sudo from the user you want to install for. Try 'sudo $0'"
exit 1
fi
__backtitle="retropie.org.uk - RetroPie Setup. Installation folder: $rootdir for user $user"
source "$scriptdir/scriptmodules/system.sh"
source "$scriptdir/scriptmodules/helpers.sh"
source "$scriptdir/scriptmodules/inifuncs.sh"
source "$scriptdir/scriptmodules/packages.sh"
setup_env
rp_registerAllModules
ensureFBMode 320 240
rp_ret=0
if [[ $# -gt 0 ]]; then
setupDirectories
rp_callModule "$@"
rp_ret=$?
else
rp_printUsageinfo
fi
if [[ "${#__ERRMSGS[@]}" -gt 0 ]]; then
# override return code if ERRMSGS is set - eg in the case of calling basic_install from setup
# we won't get the return code, as we don't handle return codes when calling non packaging functions
# as it would require all modules functions to handle errors differently, and make things more complicated
[[ "$rp_ret" -eq 0 ]] && rp_ret=1
printMsgs "console" "Errors:\n${__ERRMSGS[@]}"
fi
if [[ "${#__INFMSGS[@]}" -gt 0 ]]; then
printMsgs "console" "Info:\n${__INFMSGS[@]}"
fi
exit $rp_ret