*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
/*****************************************************************************
else
{
/* msg dbg relative ? */
- char *psz_absolute = alloca( strlen( p_demux->psz_access ) + 3 + strlen( p_demux->psz_path ) + strlen( psz_ref ) + 1);
+ int i_path_size = strlen( p_demux->psz_access ) + 3 +
+ strlen( p_demux->psz_path ) + strlen( psz_ref ) + 1;
+#ifdef HAVE_ALLOCA
+ char *psz_absolute = alloca( i_path_size );
+#else
+ char *psz_absolute = (char *)malloc( i_path_size );
+#endif
char *end = strrchr( p_demux->psz_path, '/' );
if( end )
b_play = VLC_TRUE;
}
}
+#ifndef HAVE_ALLOCA
+ free( psz_absolute );
+#endif
}
}
else
case( VLC_FOURCC( 'm', 's', 0x00, 0x55 ) ):
p_track->fmt.i_codec = VLC_FOURCC( 'm', 'p', 'g', 'a' );
break;
+
case( VLC_FOURCC( 'r', 'a', 'w', ' ' ) ):
p_track->fmt.i_codec = VLC_FOURCC( 'a', 'r', 'a', 'w' );
+
+ /* Buggy files workaround */
+ if( p_sample->data.p_sample_soun && (p_track->i_timescale !=
+ p_sample->data.p_sample_soun->i_sampleratehi) )
+ {
+ MP4_Box_data_sample_soun_t *p_soun =
+ p_sample->data.p_sample_soun;
+
+ msg_Warn( p_demux, "i_timescale ("I64Fu") != i_sampleratehi "
+ "(%u), making both equal (report any problem).",
+ p_track->i_timescale, p_soun->i_sampleratehi );
+
+ if( p_soun->i_sampleratehi )
+ p_track->i_timescale = p_soun->i_sampleratehi;
+ else
+ p_soun->i_sampleratehi = p_track->i_timescale;
+ }
break;
+
case( VLC_FOURCC( 's', '2', '6', '3' ) ):
p_track->fmt.i_codec = VLC_FOURCC( 'h', '2', '6', '3' );
break;
if( p_track->fmt.i_cat == SPU_ES )
{
p_track->fmt.i_codec = VLC_FOURCC( 's','p','u',' ' );
+ if( p_track->i_width > 0 )
+ p_track->fmt.subs.spu.i_original_frame_width = p_track->i_width;
+ if( p_track->i_height > 0 )
+ p_track->fmt.subs.spu.i_original_frame_height = p_track->i_height;
break;
}
/* Fallback */
case( VIDEO_ES ):
p_track->fmt.video.i_width = p_sample->data.p_sample_vide->i_width;
p_track->fmt.video.i_height = p_sample->data.p_sample_vide->i_height;
+ p_track->fmt.video.i_bits_per_pixel =
+ p_sample->data.p_sample_vide->i_depth;
/* fall on display size */
if( p_track->fmt.video.i_width <= 0 )
break;
}
- if( i_start >= p_track->chunk[i_chunk].i_first_dts &&
- i_start < p_track->chunk[i_chunk + 1].i_first_dts )
+ if( (uint64_t)i_start >= p_track->chunk[i_chunk].i_first_dts &&
+ (uint64_t)i_start < p_track->chunk[i_chunk + 1].i_first_dts )
{
break;
}
{
if( i_dts +
p_track->chunk[i_chunk].p_sample_count_dts[i_index] *
- p_track->chunk[i_chunk].p_sample_delta_dts[i_index] < i_start )
+ p_track->chunk[i_chunk].p_sample_delta_dts[i_index] < (uint64_t)i_start )
{
i_dts +=
p_track->chunk[i_chunk].p_sample_count_dts[i_index] *
if( ( p_track->p_elst = p_elst = MP4_BoxGet( p_box_trak, "edts/elst" ) ) )
{
MP4_Box_data_elst_t *elst = p_elst->data.p_elst;
- int i;
+ unsigned int i;
msg_Warn( p_demux, "elst box found" );
for( i = 0; i < elst->i_entry_count; i++ )
"ms) rate=%d.%d", i,
elst->i_segment_duration[i] * 1000 / p_sys->i_timescale,
elst->i_media_time[i] >= 0 ?
- elst->i_media_time[i] * 1000 / p_track->i_timescale : -1,
+ (int64_t)(elst->i_media_time[i] * 1000 / p_track->i_timescale) :
+ I64C(-1),
elst->i_media_rate_integer[i],
elst->i_media_rate_fraction[i] );
}
}
}
- /* fxi i_timescale for AUDIO_ES with i_qt_version == 0 */
- if( p_track->fmt.i_cat == AUDIO_ES ) //&& p_track->i_sample_size == 1 )
- {
- MP4_Box_t *p_sample;
-
- p_sample = MP4_BoxGet( p_track->p_stsd, "[0]" );
- if( p_sample && p_sample->data.p_sample_soun)
- {
- MP4_Box_data_sample_soun_t *p_soun = p_sample->data.p_sample_soun;
- if( p_soun->i_qt_version == 0 &&
- p_track->i_timescale != p_soun->i_sampleratehi )
- {
- msg_Warn( p_demux,
- "i_timescale ("I64Fu") != i_sampleratehi (%u) with "
- "qt_version == 0\n"
- "Making both equal. (report any problem)",
- p_track->i_timescale, p_soun->i_sampleratehi );
-
- if( p_soun->i_sampleratehi )
- p_track->i_timescale = p_soun->i_sampleratehi;
- else
- p_soun->i_sampleratehi = p_track->i_timescale;
- }
- }
- }
-
/* Create chunk index table and sample index table */
if( TrackCreateChunksIndex( p_demux,p_track ) ||
TrackCreateSamplesIndex( p_demux, p_track ) )
{
demux_sys_t *p_sys = p_demux->p_sys;
MP4_Box_data_elst_t *elst = p_track->p_elst->data.p_elst;
- int64_t i_mvt = MP4_TrackGetDTS( p_demux, p_track ) *
+ uint64_t i_mvt = MP4_TrackGetDTS( p_demux, p_track ) *
p_sys->i_timescale / (int64_t)1000000;
- if( p_track->i_elst < elst->i_entry_count &&
+ if( (unsigned int)p_track->i_elst < elst->i_entry_count &&
i_mvt >= p_track->i_elst_time +
elst->i_segment_duration[p_track->i_elst] )
{
MP4_Box_data_elst_t *elst = tk->p_elst->data.p_elst;
int64_t i_mvt= i_time * p_sys->i_timescale / (int64_t)1000000;
- for( tk->i_elst = 0; tk->i_elst < elst->i_entry_count; tk->i_elst++ )
+ for( tk->i_elst = 0; (unsigned int)tk->i_elst < elst->i_entry_count; tk->i_elst++ )
{
mtime_t i_dur = elst->i_segment_duration[tk->i_elst];
tk->i_elst_time += i_dur;
}
- if( tk->i_elst >= elst->i_entry_count )
+ if( (unsigned int)tk->i_elst >= elst->i_entry_count )
{
/* msg_Dbg( p_demux, "invalid number of entry in elst" ); */
tk->i_elst = elst->i_entry_count - 1;