diff options
author | Marco Nelissen <marcone@google.com> | 2012-04-13 16:00:41 -0700 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2012-04-13 16:00:41 -0700 |
commit | fbe308d428e42fe249ec317f76e3d11feb3264d5 (patch) | |
tree | ec5519aa319720a34151463529558d923a53d580 /media | |
parent | 25736fd247ba757feefe15d3071f7e747c64fea4 (diff) | |
parent | a28976b04c70cef3c8e79137478b6a7bc05608ac (diff) | |
download | frameworks_av-fbe308d428e42fe249ec317f76e3d11feb3264d5.zip frameworks_av-fbe308d428e42fe249ec317f76e3d11feb3264d5.tar.gz frameworks_av-fbe308d428e42fe249ec317f76e3d11feb3264d5.tar.bz2 |
Merge "Make mediascanner use filedescriptors instead of paths"
Diffstat (limited to 'media')
-rw-r--r-- | media/libstagefright/StagefrightMediaScanner.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/media/libstagefright/StagefrightMediaScanner.cpp b/media/libstagefright/StagefrightMediaScanner.cpp index 711a8cd..b7cf96e 100644 --- a/media/libstagefright/StagefrightMediaScanner.cpp +++ b/media/libstagefright/StagefrightMediaScanner.cpp @@ -18,6 +18,10 @@ #define LOG_TAG "StagefrightMediaScanner" #include <utils/Log.h> +#include <sys/types.h> +#include <sys/stat.h> +#include <fcntl.h> + #include <media/stagefright/StagefrightMediaScanner.h> #include <media/mediametadataretriever.h> @@ -139,7 +143,16 @@ MediaScanResult StagefrightMediaScanner::processFileInternal( sp<MediaMetadataRetriever> mRetriever(new MediaMetadataRetriever); - status_t status = mRetriever->setDataSource(path); + int fd = open(path, O_RDONLY | O_LARGEFILE); + status_t status; + if (fd < 0) { + // couldn't open it locally, maybe the media server can? + status = mRetriever->setDataSource(path); + } else { + status = mRetriever->setDataSource(fd, 0, 0x7ffffffffffffffL); + close(fd); + } + if (status) { return MEDIA_SCAN_RESULT_ERROR; } |