* This workaround for recovery.fstab was only necessary for CM recovery, however the recovery will be fixed properly soon, so there is no need for this workaround Change-Id: Ib7db0997d1059e9829d9ca4b4a8c208d43bc46b6 Signed-off-by: Paul Keith <javelinanddart@bestas.gr>
96 lines
1.8 KiB
Bash
96 lines
1.8 KiB
Bash
#!/sbin/sh
|
|
|
|
OUTFD="/proc/self/fd/$2"
|
|
ZIP=$3
|
|
|
|
exec_util() {
|
|
LD_LIBRARY_PATH=$LD_PATH $UTILS $1
|
|
}
|
|
|
|
set_con() {
|
|
exec_util "chcon -h u:object_r:"$1":s0 $2"
|
|
exec_util "chcon u:object_r:"$1":s0 $2"
|
|
}
|
|
|
|
set_perm() {
|
|
exec_util "chmod $1 $2"
|
|
}
|
|
|
|
set_owner() {
|
|
exec_util "chown $1:$2 $3"
|
|
}
|
|
|
|
ui_print() {
|
|
echo "ui_print $1" > "$OUTFD";
|
|
echo "ui_print" > "$OUTFD";
|
|
}
|
|
|
|
ui_print "**********************"
|
|
ui_print "MindTheGapps installer"
|
|
ui_print "**********************"
|
|
|
|
ui_print "Mounting /system"
|
|
|
|
if mount /system; then
|
|
ui_print "/system mounted"
|
|
else
|
|
ui_print "Could not mount /system! Aborting"
|
|
exit 1
|
|
fi
|
|
|
|
if [ -f /system/bin/toybox ]; then
|
|
UTILS=/system/bin/toybox
|
|
LD_PATH=/system/lib
|
|
else
|
|
ui_print "Could not find /system/bin/toybox! Aborting"
|
|
exit 1
|
|
fi
|
|
|
|
DIRS="addon.d app priv-app framework etc lib"
|
|
|
|
if [ -d /system/lib64 ]; then
|
|
DIRS="$DIRS lib64"
|
|
LD_PATH=/system/lib64
|
|
fi
|
|
|
|
ui_print "Extracting files"
|
|
cd /tmp
|
|
unzip -o "$ZIP" system/*
|
|
cd system
|
|
ui_print "Generating addon.d file"
|
|
cat addon.d/addond_head > addon.d/30-gapps.sh
|
|
for f in `exec_util "find . -type f"`; do
|
|
line=$(echo "$f" | sed 's/\.\///')
|
|
echo "$line" >> addon.d/30-gapps.sh
|
|
done
|
|
cat addon.d/addond_tail >> addon.d/30-gapps.sh
|
|
ui_print "Preparing files for copying"
|
|
for dirs in $DIRS; do
|
|
set_perm 0755 $dir
|
|
for d in `exec_util "find ./$dir -type d"`; do
|
|
set_perm 0755 $d
|
|
set_owner root root $d
|
|
done
|
|
for f in `exec_util "find ./$dir -type f"`; do
|
|
type=$(echo "$f" | sed 's/.*\.//')
|
|
if [ "$type" == "sh" ] || [ "$type" == "$f" ]; then
|
|
set_perm 0755 $f
|
|
else
|
|
set_perm 0644 $f
|
|
fi
|
|
set_owner root root $f
|
|
set_con system_file $f
|
|
done
|
|
done
|
|
ui_print "Copying files"
|
|
exec_util "cp --preserve=a -r ./* /system/"
|
|
ui_print "Cleaning up files"
|
|
cd ../
|
|
exec_util "rm -rf system/"
|
|
|
|
ui_print "Unmounting /system"
|
|
umount /system
|
|
|
|
ui_print "Done!"
|
|
exit 0
|