OSDN Git Service

audioconvert: define unique strings for AV_CH_LAYOUT_5POINT{0,1}_BACK
[coroid/ffmpeg_saccubus.git] / libavutil / avutil.h
1 /*
2  * copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at>
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20
21 #ifndef AVUTIL_AVUTIL_H
22 #define AVUTIL_AVUTIL_H
23
24 /**
25  * @file
26  * external API header
27  */
28
29
30 #define AV_STRINGIFY(s)         AV_TOSTRING(s)
31 #define AV_TOSTRING(s) #s
32
33 #define AV_GLUE(a, b) a ## b
34 #define AV_JOIN(a, b) AV_GLUE(a, b)
35
36 #define AV_PRAGMA(s) _Pragma(#s)
37
38 #define AV_VERSION_INT(a, b, c) (a<<16 | b<<8 | c)
39 #define AV_VERSION_DOT(a, b, c) a ##.## b ##.## c
40 #define AV_VERSION(a, b, c) AV_VERSION_DOT(a, b, c)
41
42 #define LIBAVUTIL_VERSION_MAJOR 51
43 #define LIBAVUTIL_VERSION_MINOR 11
44 #define LIBAVUTIL_VERSION_MICRO  1
45
46 #define LIBAVUTIL_VERSION_INT   AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
47                                                LIBAVUTIL_VERSION_MINOR, \
48                                                LIBAVUTIL_VERSION_MICRO)
49 #define LIBAVUTIL_VERSION       AV_VERSION(LIBAVUTIL_VERSION_MAJOR,     \
50                                            LIBAVUTIL_VERSION_MINOR,     \
51                                            LIBAVUTIL_VERSION_MICRO)
52 #define LIBAVUTIL_BUILD         LIBAVUTIL_VERSION_INT
53
54 #define LIBAVUTIL_IDENT         "Lavu" AV_STRINGIFY(LIBAVUTIL_VERSION)
55
56 /**
57  * Those FF_API_* defines are not part of public API.
58  * They may change, break or disappear at any time.
59  */
60 #ifndef FF_API_OLD_EVAL_NAMES
61 #define FF_API_OLD_EVAL_NAMES (LIBAVUTIL_VERSION_MAJOR < 52)
62 #endif
63 #ifndef FF_API_GET_BITS_PER_SAMPLE_FMT
64 #define FF_API_GET_BITS_PER_SAMPLE_FMT (LIBAVUTIL_VERSION_MAJOR < 52)
65 #endif
66 #ifndef FF_API_FIND_OPT
67 #define FF_API_FIND_OPT                 (LIBAVUTIL_VERSION_MAJOR < 52)
68 #endif
69
70 /**
71  * Return the LIBAVUTIL_VERSION_INT constant.
72  */
73 unsigned avutil_version(void);
74
75 /**
76  * Return the libavutil build-time configuration.
77  */
78 const char *avutil_configuration(void);
79
80 /**
81  * Return the libavutil license.
82  */
83 const char *avutil_license(void);
84
85 enum AVMediaType {
86     AVMEDIA_TYPE_UNKNOWN = -1,
87     AVMEDIA_TYPE_VIDEO,
88     AVMEDIA_TYPE_AUDIO,
89     AVMEDIA_TYPE_DATA,
90     AVMEDIA_TYPE_SUBTITLE,
91     AVMEDIA_TYPE_ATTACHMENT,
92     AVMEDIA_TYPE_NB
93 };
94
95 #define FF_LAMBDA_SHIFT 7
96 #define FF_LAMBDA_SCALE (1<<FF_LAMBDA_SHIFT)
97 #define FF_QP2LAMBDA 118 ///< factor to convert from H.263 QP to lambda
98 #define FF_LAMBDA_MAX (256*128-1)
99
100 #define FF_QUALITY_SCALE FF_LAMBDA_SCALE //FIXME maybe remove
101
102 #define AV_NOPTS_VALUE          INT64_C(0x8000000000000000)
103 #define AV_TIME_BASE            1000000
104 #define AV_TIME_BASE_Q          (AVRational){1, AV_TIME_BASE}
105
106 enum AVPictureType {
107     AV_PICTURE_TYPE_NONE = 0, ///< Undefined
108     AV_PICTURE_TYPE_I,     ///< Intra
109     AV_PICTURE_TYPE_P,     ///< Predicted
110     AV_PICTURE_TYPE_B,     ///< Bi-dir predicted
111     AV_PICTURE_TYPE_S,     ///< S(GMC)-VOP MPEG4
112     AV_PICTURE_TYPE_SI,    ///< Switching Intra
113     AV_PICTURE_TYPE_SP,    ///< Switching Predicted
114     AV_PICTURE_TYPE_BI,    ///< BI type
115 };
116
117 /**
118  * Return a single letter to describe the given picture type
119  * pict_type.
120  *
121  * @param[in] pict_type the picture type @return a single character
122  * representing the picture type, '?' if pict_type is unknown
123  */
124 char av_get_picture_type_char(enum AVPictureType pict_type);
125
126 #include "common.h"
127 #include "error.h"
128 #include "mathematics.h"
129 #include "rational.h"
130 #include "intfloat_readwrite.h"
131 #include "log.h"
132 #include "pixfmt.h"
133
134 #endif /* AVUTIL_AVUTIL_H */