1 /* libasf - An Advanced Systems Format media file parser
2 * Copyright (C) 2006-2010 Juho Vähä-Herttua
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 /* used int types for different platforms */
23 #if defined(WIN32) && !defined(__MINGW_H)
25 typedef unsigned char uint8_t;
26 typedef short int16_t;
27 typedef unsigned short uint16_t;
29 typedef unsigned long uint32_t;
31 typedef __int64
int64_t;
32 typedef unsigned __int64
uint64_t;
37 #if defined(WIN32) && defined(DLL_EXPORT)
38 # define LIBASF_API __declspec(dllexport)
47 /* fatal errors related to library function */
48 ASF_ERROR_INTERNAL
= -100, /* incorrect input to API calls */
49 ASF_ERROR_OUTOFMEM
= -101, /* some malloc inside program failed */
51 /* errors related to reading data from stream */
52 ASF_ERROR_NEEDS_BYTES
= -200, /* not enough data from read */
53 ASF_ERROR_EOF
= -201, /* end of file reached */
54 ASF_ERROR_IO
= -202, /* error reading or writing to file */
56 /* errors related to file being corrupted */
57 ASF_ERROR_INVALID_LENGTH
= -300, /* length value conflict in input data */
58 ASF_ERROR_INVALID_VALUE
= -301, /* other value conflict in input data */
59 ASF_ERROR_INVALID_OBJECT
= -302, /* ASF object missing or in wrong place */
60 ASF_ERROR_INVALID_OBJECT_SIZE
= -303, /* invalid ASF object size (too small) */
62 /* errors related to seeking, usually non-fatal */
63 ASF_ERROR_SEEKABLE
= -400, /* file not seekable */
64 ASF_ERROR_SEEK
= -401 /* file is seekable but seeking failed */
68 ASF_STREAM_TYPE_NONE
= 0x00,
69 ASF_STREAM_TYPE_AUDIO
= 0x01,
70 ASF_STREAM_TYPE_VIDEO
= 0x02,
71 ASF_STREAM_TYPE_COMMAND
= 0x03,
72 ASF_STREAM_TYPE_UNKNOWN
= 0xff
75 #define ASF_STREAM_FLAG_NONE 0x0000
76 #define ASF_STREAM_FLAG_AVAILABLE 0x0001
77 #define ASF_STREAM_FLAG_HIDDEN 0x0002
78 #define ASF_STREAM_FLAG_EXTENDED 0x0004
81 /* waveformatex fields specified in Microsoft documentation:
82 http://msdn2.microsoft.com/en-us/library/ms713497.aspx */
83 struct asf_waveformatex_s
{
86 uint32_t nSamplesPerSec
;
87 uint32_t nAvgBytesPerSec
;
89 uint16_t wBitsPerSample
;
93 typedef struct asf_waveformatex_s asf_waveformatex_t
;
95 #define ASF_BITMAPINFOHEADER_SIZE 40
96 /* bitmapinfoheader fields specified in Microsoft documentation:
97 http://msdn2.microsoft.com/en-us/library/ms532290.aspx */
98 struct asf_bitmapinfoheader_s
{
104 uint32_t biCompression
;
105 uint32_t biSizeImage
;
106 uint32_t biXPelsPerMeter
;
107 uint32_t biYPelsPerMeter
;
109 uint32_t biClrImportant
;
112 typedef struct asf_bitmapinfoheader_s asf_bitmapinfoheader_t
;
115 struct asf_iostream_s
{
116 /* read function, returns -1 on error, 0 on EOF and read bytes
118 int32_t (*read
)(void *opaque
, void *buffer
, int32_t size
);
120 /* write function, returns -1 on error, 0 on EOF and written
122 int32_t (*write
)(void *opaque
, void *buffer
, int32_t size
);
124 /* seek function, seeks to offset from beginning of the file,
125 * returns -1 on error, 0 on EOF */
126 int64_t (*seek
)(void *opaque
, int64_t offset
);
128 /* opaque data pointer passed to each of the stream handling
132 typedef struct asf_iostream_s asf_iostream_t
;
134 struct asf_metadata_entry_s
{
135 char *key
; /* key of extended metadata entry */
136 char *value
; /* value of extended metadata entry */
138 typedef struct asf_metadata_entry_s asf_metadata_entry_t
;
140 /* all metadata entries are presented in UTF-8 character encoding */
141 struct asf_metadata_s
{
142 char *title
; /* title of the stream */
143 char *artist
; /* artist of the stream */
144 char *copyright
; /* copyright holder */
145 char *description
; /* description of the stream */
146 char *rating
; /* rating of the stream */
147 uint16_t extended_count
; /* number of extended entries */
148 asf_metadata_entry_t
*extended
; /* array of extended entries */
150 typedef struct asf_metadata_s asf_metadata_t
;
152 struct asf_payload_s
{
153 uint8_t stream_number
; /* the stream number this payload belongs to */
154 uint8_t key_frame
; /* a flag indicating if this payload contains a key frame */
156 uint32_t media_object_number
; /* number of media object this payload is part of */
157 uint32_t media_object_offset
; /* byte offset from beginning of media object */
159 uint32_t replicated_length
; /* length of some replicated data of a media object... */
160 uint8_t *replicated_data
; /* the replicated data mentioned */
162 uint32_t datalen
; /* length of the actual payload data */
163 uint8_t *data
; /* the actual payload data to decode */
165 uint32_t pts
; /* presentation time of this payload */
167 typedef struct asf_payload_s asf_payload_t
;
169 struct asf_packet_s
{
170 uint8_t ec_length
; /* error correction data length */
171 uint8_t *ec_data
; /* error correction data array */
173 uint32_t length
; /* length of this packet, usually constant per stream */
174 uint32_t sequence
; /* sequence value reserved for future use, should be ignored */
175 uint32_t padding_length
; /* length of the padding after the data in this packet */
176 uint32_t send_time
; /* send time of this packet in milliseconds */
177 uint16_t duration
; /* duration of this packet in milliseconds */
179 uint16_t payload_count
; /* number of payloads contained in this packet */
180 asf_payload_t
*payloads
; /* an array of payloads in this packet */
181 uint16_t payloads_size
; /* for internal library use, not to be modified by applications! */
183 uint32_t payload_data_len
; /* length of the raw payload data of this packet */
184 uint8_t *payload_data
; /* the raw payload data of this packet, usually not useful */
186 uint8_t *data
; /* for internal library use, not to be modified by applications! */
187 uint32_t data_size
; /* for internal library use, not to be modified by applications! */
189 typedef struct asf_packet_s asf_packet_t
;
191 struct asf_stream_extended_properties_s
{
194 uint32_t data_bitrate
;
195 uint32_t buffer_size
;
196 uint32_t initial_buf_fullness
;
197 uint32_t data_bitrate2
;
198 uint32_t buffer_size2
;
199 uint32_t initial_buf_fullness2
;
200 uint32_t max_obj_size
;
204 uint64_t avg_time_per_frame
;
205 uint16_t stream_name_count
;
206 uint16_t num_payload_ext
;
208 typedef struct asf_stream_extended_properties_s asf_stream_extended_properties_t
;
210 struct asf_stream_s
{
211 asf_stream_type_t type
; /* type of this current stream */
212 uint16_t flags
; /* possible flags related to this stream */
214 /* pointer to type specific data (ie. waveformatex or bitmapinfoheader)
215 * only available if ASF_STREAM_FLAG_AVAILABLE flag is set, otherwise NULL */
218 /* pointer to extended properties of the stream if they specified
219 * only available if ASF_STREAM_FLAG_EXTENDED flag is set, otherwise NULL */
220 asf_stream_extended_properties_t
*extended_properties
;
222 typedef struct asf_stream_s asf_stream_t
;
224 typedef struct asf_file_s asf_file_t
;
227 /* initialize the library using file on a local filesystem */
228 LIBASF_API asf_file_t
*asf_open_file(const char *filename
);
230 /* initialize the library using callbacks defined on a stream structure,
231 the stream structure can be freed after calling this function */
232 LIBASF_API asf_file_t
*asf_open_cb(asf_iostream_t
*iostream
);
234 /* close the library handle and free all allocated memory */
235 LIBASF_API
void asf_close(asf_file_t
*file
);
238 /* initialize the library and read all header information of the ASF file */
239 LIBASF_API
int asf_init(asf_file_t
*file
);
242 /* create a packet structure for reading data packets */
243 LIBASF_API asf_packet_t
*asf_packet_create();
245 /* free the packet structure allocated earlier, need to be called only once */
246 LIBASF_API
void asf_packet_destroy(asf_packet_t
*packet
);
248 /* get next packet from the stream to the specified packet structure */
249 LIBASF_API
int asf_get_packet(asf_file_t
*file
, asf_packet_t
*packet
);
251 /* seek to the closest (key frame) packet specified by milliseconds position */
252 LIBASF_API
int64_t asf_seek_to_msec(asf_file_t
*file
, int64_t msec
);
255 /* get metadata information of the ASF file handle */
256 LIBASF_API asf_metadata_t
*asf_header_get_metadata(asf_file_t
*file
);
258 /* free metadata structure received from the library */
259 LIBASF_API
void asf_metadata_destroy(asf_metadata_t
*metadata
);
261 /* free all header information from the ASF file structure
262 * WARNING: after calling this function all asf_header_*
263 * functions will return NULL or failure!!! */
264 LIBASF_API
void asf_header_destroy(asf_file_t
*file
);
267 /* calculate how many streams are available in current ASF file */
268 LIBASF_API
uint8_t asf_get_stream_count(asf_file_t
*file
);
270 /* get info of a stream, the resulting pointer and its contents should NOT be freed */
271 LIBASF_API asf_stream_t
*asf_get_stream(asf_file_t
*file
, uint8_t track
);
274 /* return non-zero if the file is broadcasted, 0 otherwise */
275 LIBASF_API
int asf_is_broadcast(asf_file_t
*file
);
277 /* return non-zero if the file is seekable, 0 otherwise */
278 LIBASF_API
int asf_is_seekable(asf_file_t
*file
);
280 /* get size of the ASF file in bytes */
281 LIBASF_API
uint64_t asf_get_file_size(asf_file_t
*file
);
283 /* get creation date in 100-nanosecond units since Jan 1, 1601 GMT
284 this value should be ignored for broadcasts */
285 LIBASF_API
uint64_t asf_get_creation_date(asf_file_t
*file
);
287 /* get number of data packets available in this file
288 this value should be ignored for broadcasts */
289 LIBASF_API
uint64_t asf_get_data_packets(asf_file_t
*file
);
291 /* get play duration of the file in 100-nanosecond units,
292 this value should be ignored for broadcasts */
293 LIBASF_API
uint64_t asf_get_duration(asf_file_t
*file
);
295 /* maximum bitrate as bits per second in the entire file */
296 LIBASF_API
uint32_t asf_get_max_bitrate(asf_file_t
*file
);