diff options
Diffstat (limited to 'media/java/android/mtp/MtpDatabase.java')
-rwxr-xr-x | media/java/android/mtp/MtpDatabase.java | 56 |
1 files changed, 37 insertions, 19 deletions
diff --git a/media/java/android/mtp/MtpDatabase.java b/media/java/android/mtp/MtpDatabase.java index e568ef79b4cc..474b671c0c2b 100755 --- a/media/java/android/mtp/MtpDatabase.java +++ b/media/java/android/mtp/MtpDatabase.java @@ -52,11 +52,10 @@ import java.nio.file.Paths; import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; -import java.util.Iterator; +import java.util.List; import java.util.Locale; import java.util.concurrent.atomic.AtomicBoolean; import java.util.stream.IntStream; -import java.util.stream.Stream; /** * MtpDatabase provides an interface for MTP operations that MtpServer can use. To do this, it uses @@ -267,6 +266,12 @@ public class MtpDatabase implements AutoCloseable { if (MtpDatabase.this.mServer != null) MtpDatabase.this.mServer.sendObjectRemoved(id); } + + @Override + public void sendObjectInfoChanged(int id) { + if (MtpDatabase.this.mServer != null) + MtpDatabase.this.mServer.sendObjectInfoChanged(id); + } }, subDirectories == null ? null : Sets.newHashSet(subDirectories)); initDeviceProperties(context); @@ -453,21 +458,25 @@ public class MtpDatabase implements AutoCloseable { } private int[] getObjectList(int storageID, int format, int parent) { - Stream<MtpStorageManager.MtpObject> objectStream = mManager.getObjects(parent, + List<MtpStorageManager.MtpObject> objs = mManager.getObjects(parent, format, storageID); - if (objectStream == null) { + if (objs == null) { return null; } - return objectStream.mapToInt(MtpStorageManager.MtpObject::getId).toArray(); + int[] ret = new int[objs.size()]; + for (int i = 0; i < objs.size(); i++) { + ret[i] = objs.get(i).getId(); + } + return ret; } private int getNumObjects(int storageID, int format, int parent) { - Stream<MtpStorageManager.MtpObject> objectStream = mManager.getObjects(parent, + List<MtpStorageManager.MtpObject> objs = mManager.getObjects(parent, format, storageID); - if (objectStream == null) { + if (objs == null) { return -1; } - return (int) objectStream.count(); + return objs.size(); } private MtpPropertyList getObjectPropertyList(int handle, int format, int property, @@ -489,11 +498,12 @@ public class MtpDatabase implements AutoCloseable { // depth 0: single object, depth 1: immediate children return new MtpPropertyList(MtpConstants.RESPONSE_SPECIFICATION_BY_DEPTH_UNSUPPORTED); } - Stream<MtpStorageManager.MtpObject> objectStream = Stream.of(); + List<MtpStorageManager.MtpObject> objs = null; + MtpStorageManager.MtpObject thisObj = null; if (handle == 0xFFFFFFFF) { // All objects are requested - objectStream = mManager.getObjects(0, format, 0xFFFFFFFF); - if (objectStream == null) { + objs = mManager.getObjects(0, format, 0xFFFFFFFF); + if (objs == null) { return new MtpPropertyList(MtpConstants.RESPONSE_INVALID_OBJECT_HANDLE); } } else if (handle != 0) { @@ -503,7 +513,7 @@ public class MtpDatabase implements AutoCloseable { return new MtpPropertyList(MtpConstants.RESPONSE_INVALID_OBJECT_HANDLE); } if (obj.getFormat() == format || format == 0) { - objectStream = Stream.of(obj); + thisObj = obj; } } if (handle == 0 || depth == 1) { @@ -511,22 +521,30 @@ public class MtpDatabase implements AutoCloseable { handle = 0xFFFFFFFF; } // Get the direct children of root or this object. - Stream<MtpStorageManager.MtpObject> childStream = mManager.getObjects(handle, format, + objs = mManager.getObjects(handle, format, 0xFFFFFFFF); - if (childStream == null) { + if (objs == null) { return new MtpPropertyList(MtpConstants.RESPONSE_INVALID_OBJECT_HANDLE); } - objectStream = Stream.concat(objectStream, childStream); + } + if (objs == null) { + objs = new ArrayList<>(); + } + if (thisObj != null) { + objs.add(thisObj); } MtpPropertyList ret = new MtpPropertyList(MtpConstants.RESPONSE_OK); MtpPropertyGroup propertyGroup; - Iterator<MtpStorageManager.MtpObject> iter = objectStream.iterator(); - while (iter.hasNext()) { - MtpStorageManager.MtpObject obj = iter.next(); + for (MtpStorageManager.MtpObject obj : objs) { if (property == 0xffffffff) { + if (format == 0 && handle != 0 && handle != 0xffffffff) { + // return properties based on the object's format + format = obj.getFormat(); + } // Get all properties supported by this object - propertyGroup = mPropertyGroupsByFormat.get(obj.getFormat()); + // format should be the same between get & put + propertyGroup = mPropertyGroupsByFormat.get(format); if (propertyGroup == null) { int[] propertyList = getSupportedObjectProperties(format); propertyGroup = new MtpPropertyGroup(mMediaProvider, mVolumeName, |