/*************************************************************************** copyright : (C) 2002, 2003, 2006 by Jochen Issing email : jochen.issing@isign-softart.de ***************************************************************************/ /*************************************************************************** * This library is free software; you can redistribute it and/or modify * * it under the terms of the GNU Lesser General Public License version * * 2.1 as published by the Free Software Foundation. * * * * This library 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 * * Lesser General Public License for more details. * * * * You should have received a copy of the GNU Lesser General Public * * License along with this library; if not, write to the Free Software * * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, * * MA 02110-1301 USA * ***************************************************************************/ #include "tlist.h" #include #include "mp4ilstbox.h" #include "boxfactory.h" #include "mp4file.h" using namespace TagLib; class MP4::Mp4IlstBox::Mp4IlstBoxPrivate { public: //! container for all boxes in ilst box TagLib::List ilstBoxes; //! a box factory for creating the appropriate boxes MP4::BoxFactory boxfactory; }; // class Mp4IlstBoxPrivate MP4::Mp4IlstBox::Mp4IlstBox( TagLib::File* file, MP4::Fourcc fourcc, TagLib::uint size, long offset ) : Mp4IsoBox( file, fourcc, size, offset ) { d = new MP4::Mp4IlstBox::Mp4IlstBoxPrivate(); } MP4::Mp4IlstBox::~Mp4IlstBox() { TagLib::List::Iterator delIter; for( delIter = d->ilstBoxes.begin(); delIter != d->ilstBoxes.end(); delIter++ ) { delete *delIter; } delete d; } void MP4::Mp4IlstBox::parse() { #if 0 std::cout << " parsing ilst box" << std::endl; #endif TagLib::MP4::File* mp4file = static_cast( file() ); TagLib::uint totalsize = 8; // parse all contained boxes TagLib::uint size; MP4::Fourcc fourcc; #if 0 std::cout << " "; #endif while( (mp4file->readSizeAndType( size, fourcc ) == true) ) { totalsize += size; // check for errors if( totalsize > MP4::Mp4IsoBox::size() ) { std::cerr << "Error in mp4 file " << mp4file->name() << " ilst box contains bad box with name: " << fourcc.toString() << std::endl; return; } // create the appropriate subclass and parse it MP4::Mp4IsoBox* curbox = d->boxfactory.createInstance( mp4file, fourcc, size, mp4file->tell() ); curbox->parsebox(); d->ilstBoxes.append( curbox ); // check for end of ilst box if( totalsize == MP4::Mp4IsoBox::size() ) break; #if 0 std::cout << " "; #endif } }