summaryrefslogtreecommitdiff
path: root/Meta/build-native-partition.sh
diff options
context:
space:
mode:
Diffstat (limited to 'Meta/build-native-partition.sh')
-rwxr-xr-xMeta/build-native-partition.sh47
1 files changed, 47 insertions, 0 deletions
diff --git a/Meta/build-native-partition.sh b/Meta/build-native-partition.sh
new file mode 100755
index 0000000000..71ddf11c17
--- /dev/null
+++ b/Meta/build-native-partition.sh
@@ -0,0 +1,47 @@
+#!/bin/sh
+
+set -e
+
+die() {
+ echo "die: $*"
+ exit 1
+}
+
+cleanup() {
+ if [ -d mnt ]; then
+ umount mnt || ( sleep 1 && sync && umount mnt )
+ rmdir mnt
+ echo "done"
+ fi
+}
+
+if [ "$(id -u)" != 0 ]; then
+ sudo -E -- "$0" "$@" || die "this script needs to run as root"
+ exit 0
+else
+ : "${SUDO_UID:=0}" "${SUDO_GID:=0}"
+fi
+
+if [ -z "$SERENITY_TARGET_INSTALL_PARTITION" ]; then
+ die "SERENITY_TARGET_INSTALL_PARTITION environment variable was not set!"
+fi
+
+printf "verifying partition %s is already ext2... " "$SERENITY_TARGET_INSTALL_PARTITION"
+if file -sL "$SERENITY_TARGET_INSTALL_PARTITION" 2>&1 | grep "ext2" > /dev/null; then
+ echo "done"
+else
+ die "$SERENITY_TARGET_INSTALL_PARTITION is not an ext2 partition!"
+fi
+
+trap cleanup EXIT
+
+printf "mounting filesystem on device %s... " "$SERENITY_TARGET_INSTALL_PARTITION"
+mkdir -p mnt
+if ! eval "mount $SERENITY_TARGET_INSTALL_PARTITION mnt/"; then
+ die "could not mount existing ext2 filesystem on $SERENITY_TARGET_INSTALL_PARTITION"
+else
+ echo "done"
+fi
+
+script_path=$(cd -P -- "$(dirname -- "$0")" && pwd -P)
+"$script_path/build-root-filesystem.sh"