/* ** ** Copyright 2009, The Android Open Source Project ** ** Licensed under the Apache License, Version 2.0 (the "License"); ** you may not use this file except in compliance with the License. ** You may obtain a copy of the License at ** ** http://www.apache.org/licenses/LICENSE-2.0 ** ** Unless required by applicable law or agreed to in writing, software ** distributed under the License is distributed on an "AS IS" BASIS, ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ** See the License for the specific language governing permissions and ** limitations under the License. */ //#define LOG_NDEBUG 0 #define LOG_TAG "VorbisMetadataRetriever" #include #include "VorbisMetadataRetriever.h" #include # namespace android { void VorbisMetadataRetriever::clearMetadataValues() { LOGV("cleearMetadataValues"); mMetadataValues[0][0] = '\0'; } status_t VorbisMetadataRetriever::setDataSource(const char *url) { LOGV("setDataSource: url(%s)", url? url: "NULL pointer"); Mutex::Autolock lock(mLock); clearMetadataValues(); if (mVorbisPlayer == 0) { mVorbisPlayer = new VorbisPlayer(); } // TODO: support headers in MetadataRetriever interface! return mVorbisPlayer->setDataSource(url, NULL /* headers */); } status_t VorbisMetadataRetriever::setDataSource(int fd, int64_t offset, int64_t length) { LOGV("setDataSource: fd(%d), offset(%lld), and length(%lld)", fd, offset, length); Mutex::Autolock lock(mLock); clearMetadataValues(); if (mVorbisPlayer == 0) { mVorbisPlayer = new VorbisPlayer(); } return mVorbisPlayer->setDataSource(fd, offset, length); } const char* VorbisMetadataRetriever::extractMetadata(int keyCode) { LOGV("extractMetadata: key(%d)", keyCode); Mutex::Autolock lock(mLock); if (mVorbisPlayer == 0 || mVorbisPlayer->initCheck() != NO_ERROR) { LOGE("no vorbis player is initialized yet"); return NULL; } switch (keyCode) { case METADATA_KEY_DURATION: { if (mMetadataValues[0][0] == '\0') { int duration = -1; if (mVorbisPlayer->getDuration(&duration) != NO_ERROR) { LOGE("failed to get duration"); return NULL; } snprintf(mMetadataValues[0], MAX_METADATA_STRING_LENGTH, "%d", duration); } LOGV("duration: %s ms", mMetadataValues[0]); return mMetadataValues[0]; } default: LOGE("Unsupported key code (%d)", keyCode); return NULL; } return NULL; } };