annotate postprocess.h @ 116:a4769eff95f0 libpostproc

Add backwards-compatibility typedef for removed _t names under appropriate version #ifdef since otherwise public API is broken.
author diego
date Thu, 11 Dec 2008 21:05:31 +0000
parents 213fc392f0c0
children 1500ae6cf66c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
1 /*
22
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
2 * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at)
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
3 *
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
4 * This file is part of FFmpeg.
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
5 *
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
6 * FFmpeg is free software; you can redistribute it and/or modify
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
7 * it under the terms of the GNU General Public License as published by
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
8 * the Free Software Foundation; either version 2 of the License, or
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
9 * (at your option) any later version.
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
10 *
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
11 * FFmpeg is distributed in the hope that it will be useful,
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
14 * GNU General Public License for more details.
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
15 *
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
16 * You should have received a copy of the GNU General Public License
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
17 * along with FFmpeg; if not, write to the Free Software
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
da3bfee1fa67 Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents: 0
diff changeset
19 */
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
20
110
858be852c955 Globally rename the header inclusion guard names.
stefano
parents: 95
diff changeset
21 #ifndef POSTPROCESS_POSTPROCESS_H
858be852c955 Globally rename the header inclusion guard names.
stefano
parents: 95
diff changeset
22 #define POSTPROCESS_POSTPROCESS_H
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
23
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
24 /**
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
25 * @file postprocess.h
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
26 * @brief
87
7ed41146fb7e misc spelling fixes
diego
parents: 82
diff changeset
27 * external postprocessing API
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
28 */
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
29
81
8d1245b4d7fb Install headers in $prefix/include/$libname
mru
parents: 80
diff changeset
30 #include "libavutil/avutil.h"
80
279387224d8c #include avutil.h in postprocess.h
mru
parents: 79
diff changeset
31
82
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
32 #define LIBPOSTPROC_VERSION_MAJOR 51
111
bf39174d9785 Implement postproc_version().
stefano
parents: 110
diff changeset
33 #define LIBPOSTPROC_VERSION_MINOR 2
82
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
34 #define LIBPOSTPROC_VERSION_MICRO 0
79
f40477ade122 Clean up lib* version definitions
mru
parents: 78
diff changeset
35
82
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
36 #define LIBPOSTPROC_VERSION_INT AV_VERSION_INT(LIBPOSTPROC_VERSION_MAJOR, \
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
37 LIBPOSTPROC_VERSION_MINOR, \
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
38 LIBPOSTPROC_VERSION_MICRO)
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
39 #define LIBPOSTPROC_VERSION AV_VERSION(LIBPOSTPROC_VERSION_MAJOR, \
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
40 LIBPOSTPROC_VERSION_MINOR, \
f69ff6d3abe3 less preprocessor magic in version number macros
mru
parents: 81
diff changeset
41 LIBPOSTPROC_VERSION_MICRO)
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
42 #define LIBPOSTPROC_BUILD LIBPOSTPROC_VERSION_INT
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
43
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
44 #define LIBPOSTPROC_IDENT "postproc" AV_STRINGIFY(LIBPOSTPROC_VERSION)
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
45
111
bf39174d9785 Implement postproc_version().
stefano
parents: 110
diff changeset
46 /**
bf39174d9785 Implement postproc_version().
stefano
parents: 110
diff changeset
47 * Returns the LIBPOSTPROC_VERSION_INT constant.
bf39174d9785 Implement postproc_version().
stefano
parents: 110
diff changeset
48 */
bf39174d9785 Implement postproc_version().
stefano
parents: 110
diff changeset
49 unsigned postproc_version(void);
bf39174d9785 Implement postproc_version().
stefano
parents: 110
diff changeset
50
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
51 #define PP_QUALITY_MAX 6
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
52
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
53 #define QP_STORE_T int8_t
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
54
53
e6a94aa12c17 Fix 'make checkheaders'.
diego
parents: 44
diff changeset
55 #include <inttypes.h>
e6a94aa12c17 Fix 'make checkheaders'.
diego
parents: 44
diff changeset
56
115
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
57 typedef void pp_context;
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
58 typedef void pp_mode;
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
59
70
6539cfc12739 Make pp_help a constant array of characters to move it to .rodata.
benoit
parents: 66
diff changeset
60 #if LIBPOSTPROC_VERSION_INT < (52<<16)
116
a4769eff95f0 Add backwards-compatibility typedef for removed _t names under appropriate
diego
parents: 115
diff changeset
61 typedef pp_context pp_context_t;
a4769eff95f0 Add backwards-compatibility typedef for removed _t names under appropriate
diego
parents: 115
diff changeset
62 typedef pp_mode pp_mode_t;
66
7737e39e74f3 Make pp_help a constant pointer to constant characters, moves it partially
benoit
parents: 65
diff changeset
63 extern const char *const pp_help; ///< a simple help text
70
6539cfc12739 Make pp_help a constant array of characters to move it to .rodata.
benoit
parents: 66
diff changeset
64 #else
6539cfc12739 Make pp_help a constant array of characters to move it to .rodata.
benoit
parents: 66
diff changeset
65 extern const char pp_help[]; ///< a simple help text
6539cfc12739 Make pp_help a constant array of characters to move it to .rodata.
benoit
parents: 66
diff changeset
66 #endif
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
67
78
michael
parents: 70
diff changeset
68 void pp_postprocess(const uint8_t * src[3], const int srcStride[3],
95
c24dab9bca80 cosmetics: Fix indentation to be 4 spaces and consistently place {}.
diego
parents: 94
diff changeset
69 uint8_t * dst[3], const int dstStride[3],
c24dab9bca80 cosmetics: Fix indentation to be 4 spaces and consistently place {}.
diego
parents: 94
diff changeset
70 int horizontalSize, int verticalSize,
c24dab9bca80 cosmetics: Fix indentation to be 4 spaces and consistently place {}.
diego
parents: 94
diff changeset
71 const QP_STORE_T *QP_store, int QP_stride,
115
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
72 pp_mode *mode, pp_context *ppContext, int pict_type);
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
73
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
74
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
75 /**
115
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
76 * returns a pp_mode or NULL if an error occurred
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
77 * name is the string after "-pp" on the command line
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
78 * quality is a number from 0 to PP_QUALITY_MAX
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
79 */
115
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
80 pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality);
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
81 void pp_free_mode(pp_mode *mode);
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
82
115
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
83 pp_context *pp_get_context(int width, int height, int flags);
213fc392f0c0 Drop _t from typedef names for POSIX compatibility.
diego
parents: 111
diff changeset
84 void pp_free_context(pp_context *ppContext);
0
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
85
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
86 #define PP_CPU_CAPS_MMX 0x80000000
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
87 #define PP_CPU_CAPS_MMX2 0x20000000
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
88 #define PP_CPU_CAPS_3DNOW 0x40000000
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
89 #define PP_CPU_CAPS_ALTIVEC 0x10000000
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
90
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
91 #define PP_FORMAT 0x00000008
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
92 #define PP_FORMAT_420 (0x00000011|PP_FORMAT)
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
93 #define PP_FORMAT_422 (0x00000001|PP_FORMAT)
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
94 #define PP_FORMAT_411 (0x00000002|PP_FORMAT)
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
95 #define PP_FORMAT_444 (0x00000000|PP_FORMAT)
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
96
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
97 #define PP_PICT_TYPE_QP2 0x00000010 ///< MPEG2 style QScale
7c419ceafa6a libavcodec/libpostproc ---> libpostproc
diego
parents:
diff changeset
98
110
858be852c955 Globally rename the header inclusion guard names.
stefano
parents: 95
diff changeset
99 #endif /* POSTPROCESS_POSTPROCESS_H */