00001 /***************************************************************** 00002 | 00003 | AP4 - File Processor 00004 | 00005 | Copyright 2003 Gilles Boccon-Gibod & Julien Boeuf 00006 | 00007 | 00008 | This file is part of Bento4/AP4 (MP4 Atom Processing Library). 00009 | 00010 | Unless you have obtained Bento4 under a difference license, 00011 | this version of Bento4 is Bento4|GPL. 00012 | Bento4|GPL is free software; you can redistribute it and/or modify 00013 | it under the terms of the GNU General Public License as published by 00014 | the Free Software Foundation; either version 2, or (at your option) 00015 | any later version. 00016 | 00017 | Bento4|GPL is distributed in the hope that it will be useful, 00018 | but WITHOUT ANY WARRANTY; without even the implied warranty of 00019 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00020 | GNU General Public License for more details. 00021 | 00022 | You should have received a copy of the GNU General Public License 00023 | along with Bento4|GPL; see the file COPYING. If not, write to the 00024 | Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 00025 | 02111-1307, USA. 00026 | 00027 ****************************************************************/ 00028 00029 #ifndef _AP4_PROCESSOR_H_ 00030 #define _AP4_PROCESSOR_H_ 00031 00032 /*---------------------------------------------------------------------- 00033 | includes 00034 +---------------------------------------------------------------------*/ 00035 #include "Ap4Types.h" 00036 #include "Ap4AtomFactory.h" 00037 00038 /*---------------------------------------------------------------------- 00039 | class references 00040 +---------------------------------------------------------------------*/ 00041 class AP4_ContainerAtom; 00042 class AP4_Sample; 00043 class AP4_ByteStream; 00044 class AP4_DataBuffer; 00045 class AP4_TrakAtom; 00046 00047 /*---------------------------------------------------------------------- 00048 | AP4_Processor 00049 +---------------------------------------------------------------------*/ 00050 class AP4_Processor { 00051 public: 00057 class ProgressListener { 00058 public: 00059 virtual ~ProgressListener() {} 00060 00071 virtual AP4_Result OnProgress(unsigned int step, 00072 unsigned int total) = 0; 00073 }; 00074 00080 class TrackHandler { 00081 public: 00085 virtual ~TrackHandler() {} 00086 00092 virtual AP4_Size GetProcessedSampleSize(AP4_Sample& sample); 00093 00098 virtual AP4_Result ProcessTrack() { return AP4_SUCCESS; } 00099 00106 virtual AP4_Result ProcessSample(AP4_DataBuffer& data_in, 00107 AP4_DataBuffer& data_out) = 0; 00108 }; 00109 00113 virtual ~AP4_Processor() {} 00114 00115 /* 00116 * Process the input stream into an output stream. 00117 * @param input Input stream to parse and process. 00118 * @param output Output stream to which the processed input 00119 * will be written. 00120 * @param listener Pointer to a listener, or NULL. The listener 00121 * will be called one or more times before this method returns, 00122 * with progress information. 00123 */ 00124 AP4_Result Process(AP4_ByteStream& input, 00125 AP4_ByteStream& output, 00126 ProgressListener* listener = NULL, 00127 AP4_AtomFactory& atom_factory = 00128 AP4_DefaultAtomFactory::Instance); 00129 00139 virtual AP4_Result Initialize(AP4_AtomParent& top_level, 00140 ProgressListener* listener = NULL); 00141 00146 virtual AP4_Result Finalize(AP4_AtomParent& top_level, 00147 ProgressListener* listener = NULL); 00148 00157 virtual TrackHandler* CreateTrackHandler(AP4_TrakAtom* trak); 00158 }; 00159 00160 #endif // _AP4_PROCESSOR_H_