summaryrefslogtreecommitdiffstats
path: root/media/mtp/MtpDevice.cpp
diff options
context:
space:
mode:
authorMike Lockwood <lockwood@android.com>2010-06-11 16:34:52 -0400
committerMike Lockwood <lockwood@android.com>2010-06-11 17:47:35 -0400
commit6afc41d095ccb159f6c4705bed903b6c048b922a (patch)
treed62715a9f700f2c56418968aa1d8199e62580bad /media/mtp/MtpDevice.cpp
parent0c9e60c772ae007a68cbfa46e0d2fb429376cfd2 (diff)
downloadframeworks_av-6afc41d095ccb159f6c4705bed903b6c048b922a.zip
frameworks_av-6afc41d095ccb159f6c4705bed903b6c048b922a.tar.gz
frameworks_av-6afc41d095ccb159f6c4705bed903b6c048b922a.tar.bz2
MTP: Add host support for deleting objects.
For example, deleting pictures on a digital camera. Signed-off-by: Mike Lockwood <lockwood@android.com>
Diffstat (limited to 'media/mtp/MtpDevice.cpp')
-rw-r--r--media/mtp/MtpDevice.cpp28
1 files changed, 28 insertions, 0 deletions
diff --git a/media/mtp/MtpDevice.cpp b/media/mtp/MtpDevice.cpp
index ee35217..3aa8a35 100644
--- a/media/mtp/MtpDevice.cpp
+++ b/media/mtp/MtpDevice.cpp
@@ -179,6 +179,8 @@ MtpObjectHandleList* MtpDevice::getObjectHandles(MtpStorageID storageID,
}
MtpObjectInfo* MtpDevice::getObjectInfo(MtpObjectHandle handle) {
+ // FIXME - we might want to add some caching here
+
mRequest.reset();
mRequest.setParameter(1, handle);
if (!sendRequest(MTP_OPERATION_GET_OBJECT_INFO))
@@ -205,7 +207,33 @@ void* MtpDevice::getThumbnail(MtpObjectHandle handle, int& outLength) {
}
outLength = 0;
return NULL;
+}
+
+bool MtpDevice::deleteObject(MtpObjectHandle handle) {
+ mRequest.reset();
+ mRequest.setParameter(1, handle);
+ if (sendRequest(MTP_OPERATION_DELETE_OBJECT)) {
+ MtpResponseCode ret = readResponse();
+ if (ret == MTP_RESPONSE_OK)
+ return true;
+ }
+ return false;
+}
+MtpObjectHandle MtpDevice::getParent(MtpObjectHandle handle) {
+ MtpObjectInfo* info = getObjectInfo(handle);
+ if (info)
+ return info->mParent;
+ else
+ return -1;
+}
+
+MtpObjectHandle MtpDevice::getStorageID(MtpObjectHandle handle) {
+ MtpObjectInfo* info = getObjectInfo(handle);
+ if (info)
+ return info->mStorageID;
+ else
+ return -1;
}
MtpProperty* MtpDevice::getDevicePropDesc(MtpDeviceProperty code) {