call FreeCookie() on 0 cookies, too
git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6813 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
93df7353db
commit
c8f5115b32
@ -27,6 +27,7 @@ MediaExtractor::MediaExtractor(BDataIO *source, int32 flags)
|
|||||||
for (int32 i = 0; i < fStreamCount; i++) {
|
for (int32 i = 0; i < fStreamCount; i++) {
|
||||||
fStreamInfo[i].status = B_OK;
|
fStreamInfo[i].status = B_OK;
|
||||||
fStreamInfo[i].cookie = 0;
|
fStreamInfo[i].cookie = 0;
|
||||||
|
fStreamInfo[i].hasCookie = true;
|
||||||
fStreamInfo[i].infoBuffer = 0;
|
fStreamInfo[i].infoBuffer = 0;
|
||||||
fStreamInfo[i].infoBufferSize = 0;
|
fStreamInfo[i].infoBufferSize = 0;
|
||||||
memset(&fStreamInfo[i].encodedFormat, 0, sizeof(fStreamInfo[i].encodedFormat));
|
memset(&fStreamInfo[i].encodedFormat, 0, sizeof(fStreamInfo[i].encodedFormat));
|
||||||
@ -36,6 +37,7 @@ MediaExtractor::MediaExtractor(BDataIO *source, int32 flags)
|
|||||||
for (int32 i = 0; i < fStreamCount; i++) {
|
for (int32 i = 0; i < fStreamCount; i++) {
|
||||||
if (B_OK != fReader->AllocateCookie(i, &fStreamInfo[i].cookie)) {
|
if (B_OK != fReader->AllocateCookie(i, &fStreamInfo[i].cookie)) {
|
||||||
fStreamInfo[i].cookie = 0;
|
fStreamInfo[i].cookie = 0;
|
||||||
|
fStreamInfo[i].hasCookie = false;
|
||||||
fStreamInfo[i].status = B_ERROR;
|
fStreamInfo[i].status = B_ERROR;
|
||||||
printf("MediaExtractor::MediaExtractor: AllocateCookie for stream %ld failed\n", i);
|
printf("MediaExtractor::MediaExtractor: AllocateCookie for stream %ld failed\n", i);
|
||||||
}
|
}
|
||||||
@ -63,7 +65,7 @@ MediaExtractor::~MediaExtractor()
|
|||||||
|
|
||||||
// free all stream cookies
|
// free all stream cookies
|
||||||
for (int32 i = 0; i < fStreamCount; i++) {
|
for (int32 i = 0; i < fStreamCount; i++) {
|
||||||
if (fStreamInfo[i].cookie)
|
if (fStreamInfo[i].hasCookie)
|
||||||
fReader->FreeCookie(fStreamInfo[i].cookie);
|
fReader->FreeCookie(fStreamInfo[i].cookie);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -189,7 +191,7 @@ MediaExtractor::CreateDecoder(int32 stream, Decoder **decoder, media_codec_info
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
res = _CreateDecoder(decoder, &fStreamInfo[stream].encodedFormat);
|
res = _CreateDecoder(decoder, fStreamInfo[stream].encodedFormat);
|
||||||
if (res != B_OK) {
|
if (res != B_OK) {
|
||||||
printf("MediaExtractor::CreateDecoder failed for stream %ld\n", stream);
|
printf("MediaExtractor::CreateDecoder failed for stream %ld\n", stream);
|
||||||
return res;
|
return res;
|
||||||
|
Loading…
Reference in New Issue
Block a user