Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 8577bd79 authored by Martijn Coenen's avatar Martijn Coenen Committed by Automerger Merge Worker
Browse files

Merge "Limit rename() workaround to /storage/emulated." into rvc-dev am: 5019f6c5

Change-Id: Icf36a053db6bd33c5856853d951e2fdaabc6789c
parents 226c1472 5019f6c5
Loading
Loading
Loading
Loading
+9 −1
Original line number Diff line number Diff line
@@ -7513,7 +7513,15 @@ public final class ActivityThread extends ClientTransactionHandler {
            try {
                super.rename(oldPath, newPath);
            } catch (ErrnoException e) {
                if (e.errno == OsConstants.EXDEV && oldPath.startsWith("/storage/")) {
                // On emulated volumes, we have bind mounts for /Android/data and
                // /Android/obb, which prevents move from working across those directories
                // and other directories on the filesystem. To work around that, try to
                // recover by doing a copy instead.
                // Note that we only do this for "/storage/emulated", because public volumes
                // don't have these bind mounts, neither do private volumes that are not
                // the primary storage.
                if (e.errno == OsConstants.EXDEV && oldPath.startsWith("/storage/emulated")
                        && newPath.startsWith("/storage/emulated")) {
                    Log.v(TAG, "Recovering failed rename " + oldPath + " to " + newPath);
                    try {
                        Files.move(new File(oldPath).toPath(), new File(newPath).toPath(),