annotate nut.h @ 4576:df7cc2eac54f libavformat

spelling/wording/grammar cosmetics
author diego
date Wed, 25 Feb 2009 19:10:39 +0000
parents aea6eb7fd713
children 6b9c2a6d8fa4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
1 /*
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
2 * "NUT" Container Format (de)muxer
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
3 * Copyright (c) 2006 Michael Niedermayer
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
4 *
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
5 * This file is part of FFmpeg.
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
6 *
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
11 *
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
15 * Lesser General Public License for more details.
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
16 *
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
20 */
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
21
3852
1b6245500d8c Globally rename the header inclusion guard names.
stefano
parents: 3617
diff changeset
22 #ifndef AVFORMAT_NUT_H
1b6245500d8c Globally rename the header inclusion guard names.
stefano
parents: 3617
diff changeset
23 #define AVFORMAT_NUT_H
2172
92f61ed53965 add multiple inclusion guards to headers
mru
parents: 2164
diff changeset
24
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
25 //#include <limits.h>
3286
6f61c3b36632 Use full path for #includes from another directory.
diego
parents: 3120
diff changeset
26 //#include "libavutil/adler32.h"
6f61c3b36632 Use full path for #includes from another directory.
diego
parents: 3120
diff changeset
27 //#include "libavcodec/mpegaudio.h"
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
28 #include "avformat.h"
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
29 #include "riff.h"
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
30
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
31 #define MAIN_STARTCODE (0x7A561F5F04ADULL + (((uint64_t)('N'<<8) + 'M')<<48))
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
32 #define STREAM_STARTCODE (0x11405BF2F9DBULL + (((uint64_t)('N'<<8) + 'S')<<48))
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
33 #define SYNCPOINT_STARTCODE (0xE4ADEECA4569ULL + (((uint64_t)('N'<<8) + 'K')<<48))
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
34 #define INDEX_STARTCODE (0xDD672F23E64EULL + (((uint64_t)('N'<<8) + 'X')<<48))
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
35 #define INFO_STARTCODE (0xAB68B596BA78ULL + (((uint64_t)('N'<<8) + 'I')<<48))
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
36
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
37 #define ID_STRING "nut/multimedia container\0"
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
38
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
39 #define MAX_DISTANCE (1024*32-1)
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
40
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
41 typedef enum{
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
42 FLAG_KEY = 1, ///<if set, frame is keyframe
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
43 FLAG_EOR = 2, ///<if set, stream has no relevance on presentation. (EOR)
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
44 FLAG_CODED_PTS = 8, ///<if set, coded_pts is in the frame header
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
45 FLAG_STREAM_ID = 16, ///<if set, stream_id is coded in the frame header
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
46 FLAG_SIZE_MSB = 32, ///<if set, data_size_msb is at frame header, otherwise data_size_msb is 0
2393
fc685315d568 spelling/wording cosmetics
diego
parents: 2359
diff changeset
47 FLAG_CHECKSUM = 64, ///<if set, the frame header contains a checksum
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
48 FLAG_RESERVED = 128, ///<if set, reserved_count is coded in the frame header
3042
55389742397f update flags
michael
parents: 2683
diff changeset
49 FLAG_HEADER_IDX =1024, ///<If set, header_idx is coded in the frame header.
55389742397f update flags
michael
parents: 2683
diff changeset
50 FLAG_MATCH_TIME =2048, ///<If set, match_time_delta is coded in the frame header
2393
fc685315d568 spelling/wording cosmetics
diego
parents: 2359
diff changeset
51 FLAG_CODED =4096, ///<if set, coded_flags are stored in the frame header
fc685315d568 spelling/wording cosmetics
diego
parents: 2359
diff changeset
52 FLAG_INVALID =8192, ///<if set, frame_code is invalid
4076
a5c615b9d8ec remove _t for POSIX compatibility.
michael
parents: 3852
diff changeset
53 } Flag;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
54
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
55 typedef struct {
1500
2ac9e4f39a67 index less seeking in O(log n) time
michael
parents: 1477
diff changeset
56 uint64_t pos;
2ac9e4f39a67 index less seeking in O(log n) time
michael
parents: 1477
diff changeset
57 uint64_t back_ptr;
2ac9e4f39a67 index less seeking in O(log n) time
michael
parents: 1477
diff changeset
58 // uint64_t global_key_pts;
2ac9e4f39a67 index less seeking in O(log n) time
michael
parents: 1477
diff changeset
59 int64_t ts;
4076
a5c615b9d8ec remove _t for POSIX compatibility.
michael
parents: 3852
diff changeset
60 } Syncpoint;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
61
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
62 typedef struct {
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
63 uint16_t flags;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
64 uint8_t stream_id;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
65 uint16_t size_mul;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
66 uint16_t size_lsb;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
67 int16_t pts_delta;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
68 uint8_t reserved_count;
3045
f4c7d2d8acbb Elision header demuxing support.
michael
parents: 3042
diff changeset
69 uint8_t header_idx;
4078
a3dab5ebe140 Remove comment suggesting using variables ending in _t as this would break POSIX.
michael
parents: 4076
diff changeset
70 } FrameCode;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
71
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
72 typedef struct {
1520
fe46e04555a5 10l forgot (skip non keyframes after seeking between syncpoint and the first keyframe)
michael
parents: 1500
diff changeset
73 int last_flags;
fe46e04555a5 10l forgot (skip non keyframes after seeking between syncpoint and the first keyframe)
michael
parents: 1500
diff changeset
74 int skip_until_key_frame;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
75 int64_t last_pts;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
76 int time_base_id;
2327
768d27bac3c1 make StreamContext.time_base a pointer
michael
parents: 2326
diff changeset
77 AVRational *time_base;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
78 int msb_pts_shift;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
79 int max_pts_distance;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
80 int decode_delay; //FIXME duplicate of has_b_frames
4092
aea6eb7fd713 Remove misleading comment, _t is POSIX-reserved namespace.
diego
parents: 4078
diff changeset
81 } StreamContext;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
82
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
83 typedef struct {
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
84 AVFormatContext *avf;
2331
4d1a56112d92 use a dynamic ByteIOContext instead of using the lavf buffer
michael
parents: 2327
diff changeset
85 // int written_packet_size;
4d1a56112d92 use a dynamic ByteIOContext instead of using the lavf buffer
michael
parents: 2327
diff changeset
86 // int64_t packet_start;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
87 FrameCode frame_code[256];
3045
f4c7d2d8acbb Elision header demuxing support.
michael
parents: 3042
diff changeset
88 uint8_t header_len[128];
f4c7d2d8acbb Elision header demuxing support.
michael
parents: 3042
diff changeset
89 const uint8_t *header[128];
2164
3804e39efbfd misc spelling fixes
diego
parents: 1520
diff changeset
90 uint64_t next_startcode; ///< stores the next startcode if it has already been parsed but the stream is not seekable
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
91 StreamContext *stream;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
92 unsigned int max_distance;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
93 unsigned int time_base_count;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
94 int64_t last_syncpoint_pos;
2359
1860d5b4be2e header repetition
michael
parents: 2349
diff changeset
95 int header_count;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
96 AVRational *time_base;
1500
2ac9e4f39a67 index less seeking in O(log n) time
michael
parents: 1477
diff changeset
97 struct AVTreeNode *syncpoints;
1477
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
98 } NUTContext;
56fe078ffc27 updating nut demuxer to latest spec
michael
parents:
diff changeset
99
3112
88e032ac11e7 Subtitle support. (untested)
michael
parents: 3045
diff changeset
100 extern const AVCodecTag ff_nut_subtitle_tags[];
88e032ac11e7 Subtitle support. (untested)
michael
parents: 3045
diff changeset
101
3120
ea5623a8efde Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents: 3112
diff changeset
102 typedef struct {
ea5623a8efde Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents: 3112
diff changeset
103 char str[9];
ea5623a8efde Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents: 3112
diff changeset
104 int flag;
ea5623a8efde Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents: 3112
diff changeset
105 } Dispositions;
ea5623a8efde Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents: 3112
diff changeset
106
2335
5b5e1edd462e move syncpoint timestamp resetting code to a common file
michael
parents: 2331
diff changeset
107 void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val);
2338
4a06a51ceb70 move lsb2full to common file
michael
parents: 2336
diff changeset
108 int64_t ff_lsb2full(StreamContext *stream, int64_t lsb);
4076
a5c615b9d8ec remove _t for POSIX compatibility.
michael
parents: 3852
diff changeset
109 int ff_nut_sp_pos_cmp(Syncpoint *a, Syncpoint *b);
a5c615b9d8ec remove _t for POSIX compatibility.
michael
parents: 3852
diff changeset
110 int ff_nut_sp_pts_cmp(Syncpoint *a, Syncpoint *b);
2349
a9dc7596498a move syncpoint cache related stuff to common file
michael
parents: 2338
diff changeset
111 void ff_nut_add_sp(NUTContext *nut, int64_t pos, int64_t back_ptr, int64_t ts);
2335
5b5e1edd462e move syncpoint timestamp resetting code to a common file
michael
parents: 2331
diff changeset
112
3120
ea5623a8efde Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents: 3112
diff changeset
113 extern const Dispositions ff_nut_dispositions[];
ea5623a8efde Add 'disposition' bitfield to AVStream and use it for both muxing and demuxing
eugeni
parents: 3112
diff changeset
114
3852
1b6245500d8c Globally rename the header inclusion guard names.
stefano
parents: 3617
diff changeset
115 #endif /* AVFORMAT_NUT_H */