shithub: aacdec

Download patch

ref: 0bb1af0581fd67b41814b9f6e01daad76b328bda
parent: 779598b7a137b8eefaae16af0a3e97c66bd8d26e
author: menno <menno>
date: Fri Nov 21 14:02:03 EST 2003

Now even gapless can work again

--- a/common/mp4ff/mp4atom.c
+++ b/common/mp4ff/mp4atom.c
@@ -22,7 +22,7 @@
 ** Commercial non-GPL licensing of this software is possible.
 ** For more info contact Ahead Software through [email protected].
 **
-** $Id: mp4atom.c,v 1.2 2003/11/21 18:20:56 menno Exp $
+** $Id: mp4atom.c,v 1.3 2003/11/21 19:02:02 menno Exp $
 **/
 
 #include <stdlib.h>
@@ -345,8 +345,8 @@
 {
     int32_t i;
 
-    /* version */ mp4ff_read_char(f);
-    /* flags */ mp4ff_read_int24(f);
+    mp4ff_read_char(f); /* version */
+    mp4ff_read_int24(f); /* flags */
     f->track[f->total_tracks - 1]->stts_entry_count = mp4ff_read_int32(f);
 
     f->track[f->total_tracks - 1]->stts_sample_count = (int32_t*)malloc(f->track[f->total_tracks - 1]->stts_entry_count * sizeof(int32_t));
--- a/common/mp4ff/mp4ff.c
+++ b/common/mp4ff/mp4ff.c
@@ -22,7 +22,7 @@
 ** Commercial non-GPL licensing of this software is possible.
 ** For more info contact Ahead Software through [email protected].
 **
-** $Id: mp4ff.c,v 1.2 2003/11/21 15:08:48 menno Exp $
+** $Id: mp4ff.c,v 1.3 2003/11/21 19:02:02 menno Exp $
 **/
 
 #include <stdlib.h>
@@ -233,7 +233,7 @@
 
 int32_t mp4ff_time_scale(mp4ff_t *f, int32_t track)
 {
-    return f->time_scale;
+    return f->track[track]->sampleRate;
 }
 
 int32_t mp4ff_num_samples(mp4ff_t *f, int32_t track)
--- a/common/mp4ff/mp4ff.h
+++ b/common/mp4ff/mp4ff.h
@@ -22,7 +22,7 @@
 ** Commercial non-GPL licensing of this software is possible.
 ** For more info contact Ahead Software through [email protected].
 **
-** $Id: mp4ff.h,v 1.5 2003/11/21 18:20:57 menno Exp $
+** $Id: mp4ff.h,v 1.6 2003/11/21 19:02:02 menno Exp $
 **/
 
 #ifndef MP4FF_H
@@ -111,7 +111,7 @@
     int32_t type;
     int32_t channelCount;
     int32_t sampleSize;
-    int32_t sampleRate;
+    uint16_t sampleRate;
 
     /* stsd */
     int32_t stsd_entry_count;
@@ -172,10 +172,10 @@
 
 /* mp4util.c */
 int32_t mp4ff_read_data(mp4ff_t *f, int8_t *data, int32_t size);
-int32_t mp4ff_read_int32(mp4ff_t *f);
-int32_t mp4ff_read_int24(mp4ff_t *f);
-int16_t mp4ff_read_int16(mp4ff_t *f);
-int8_t mp4ff_read_char(mp4ff_t *f);
+uint32_t mp4ff_read_int32(mp4ff_t *f);
+uint32_t mp4ff_read_int24(mp4ff_t *f);
+uint16_t mp4ff_read_int16(mp4ff_t *f);
+uint8_t mp4ff_read_char(mp4ff_t *f);
 uint32_t mp4ff_read_mp4_descr_length(mp4ff_t *f);
 int32_t mp4ff_position(mp4ff_t *f);
 int32_t mp4ff_set_position(mp4ff_t *f, int32_t position);
--- a/common/mp4ff/mp4util.c
+++ b/common/mp4ff/mp4util.c
@@ -22,7 +22,7 @@
 ** Commercial non-GPL licensing of this software is possible.
 ** For more info contact Ahead Software through [email protected].
 **
-** $Id: mp4util.c,v 1.1 2003/11/21 15:08:48 menno Exp $
+** $Id: mp4util.c,v 1.2 2003/11/21 19:02:03 menno Exp $
 **/
 
 #include "mp4ff.h"
@@ -51,7 +51,7 @@
     return f->current_position;
 }
 
-int32_t mp4ff_read_int32(mp4ff_t *f)
+uint32_t mp4ff_read_int32(mp4ff_t *f)
 {
     uint32_t result;
     uint32_t a, b, c, d;
@@ -64,10 +64,10 @@
     d = (uint8_t)data[3];
 
     result = (a<<24) | (b<<16) | (c<<8) | d;
-    return (int32_t)result;
+    return (uint32_t)result;
 }
 
-int32_t mp4ff_read_int24(mp4ff_t *f)
+uint32_t mp4ff_read_int24(mp4ff_t *f)
 {
     uint32_t result;
     uint32_t a, b, c;
@@ -79,10 +79,10 @@
     c = (uint8_t)data[2];
 
     result = (a<<16) | (b<<8) | c;
-    return (int32_t)result;
+    return (uint32_t)result;
 }
 
-int16_t mp4ff_read_int16(mp4ff_t *f)
+uint16_t mp4ff_read_int16(mp4ff_t *f)
 {
     uint32_t result;
     uint32_t a, b;
@@ -93,12 +93,12 @@
     b = (uint8_t)data[1];
 
     result = (a<<8) | b;
-    return (int16_t)result;
+    return (uint16_t)result;
 }
 
-int8_t mp4ff_read_char(mp4ff_t *f)
+uint8_t mp4ff_read_char(mp4ff_t *f)
 {
-    int8_t output;
+    uint8_t output;
     mp4ff_read_data(f, &output, 1);
     return output;
 }
--- a/frontend/main.c
+++ b/frontend/main.c
@@ -22,7 +22,7 @@
 ** Commercial non-GPL licensing of this software is possible.
 ** For more info contact Ahead Software through [email protected].
 **
-** $Id: main.c,v 1.62 2003/11/21 18:20:57 menno Exp $
+** $Id: main.c,v 1.63 2003/11/21 19:02:03 menno Exp $
 **/
 
 #ifdef _WIN32
@@ -832,6 +832,7 @@
         buffer_size = 0;
 
         dur = mp4ff_get_sample_duration(infile, track, sampleId);
+        printf("%d\n", dur);
         rc = mp4ff_read_sample(infile, track, sampleId, &buffer,  &buffer_size);
         if (rc == 0)
         {