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;
}