www.pudn.com > simplec++codeforp2p.rar > mp3.cpp
// ------------------------------------------------
// File : mp3.cpp
// Date: 28-may-2003
// Author: giles
//
// (c) 2002-3 peercast.org
// ------------------------------------------------
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// ------------------------------------------------
#include "channel.h"
#include "mp3.h"
// ------------------------------------------
void MP3Stream::readEnd(Stream &,Channel *)
{
}
// ------------------------------------------
void MP3Stream::readHeader(Stream &,Channel *)
{
}
// ------------------------------------------
int MP3Stream::readPacket(Stream &in,Channel *ch)
{
ChanPacket pack;
if (ch->icyMetaInterval)
{
int rlen = ch->icyMetaInterval;
while (rlen)
{
int rl = rlen;
if (rl > ChanMgr::MAX_METAINT)
rl = ChanMgr::MAX_METAINT;
pack.init(ChanPacket::T_DATA,pack.data,rl,ch->streamPos);
in.read(pack.data,pack.len);
ch->newPacket(pack);
ch->checkReadDelay(pack.len);
ch->streamPos+=pack.len;
rlen-=rl;
}
unsigned char len;
in.read(&len,1);
if (len)
{
if (len*16 > 1024) len = 1024/16;
char buf[1024];
in.read(buf,len*16);
ch->processMp3Metadata(buf);
}
}else{
pack.init(ChanPacket::T_DATA,pack.data,ChanMgr::MAX_METAINT,ch->streamPos);
in.read(pack.data,pack.len);
ch->newPacket(pack);
ch->checkReadDelay(pack.len);
ch->streamPos += pack.len;
}
return 0;
}