libavutil/version.h
c41899a3
 /*
  * copyright (c) 2003 Fabrice Bellard
  *
  * This file is part of FFmpeg.
  *
  * FFmpeg is free software; you can redistribute it and/or
  * modify it under the terms of the GNU Lesser General Public
  * License as published by the Free Software Foundation; either
  * version 2.1 of the License, or (at your option) any later version.
  *
  * FFmpeg is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with FFmpeg; if not, write to the Free Software
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  */
 
58c7bf78
 /**
  * @file
  * @ingroup lavu
  * Libavutil version macros
  */
 
c41899a3
 #ifndef AVUTIL_VERSION_H
 #define AVUTIL_VERSION_H
 
9a4c10e3
 #include "macros.h"
86ab7b0f
 
183117fe
 /**
0201ce00
  * @addtogroup version_utils
183117fe
  *
  * Useful to check and match library version in order to maintain
  * backward compatibility.
  *
adbf1c90
  * The FFmpeg libraries follow a versioning sheme very similar to
  * Semantic Versioning (http://semver.org/)
  * The difference is that the component called PATCH is called MICRO in FFmpeg
  * and its value is reset to 100 instead of 0 to keep it above or equal to 100.
  * Also we do not increase MICRO for every bugfix or change in git master.
  *
ac028794
  * Prior to FFmpeg 3.2 point releases did not change any lib version number to
  * avoid aliassing different git master checkouts.
  * Starting with FFmpeg 3.2, the released library versions will occupy
  * a separate MAJOR.MINOR that is not used on the master development branch.
  * That is if we branch a release of master 55.10.123 we will bump to 55.11.100
  * for the release and master will continue at 55.12.100 after it. Each new
  * point release will then bump the MICRO improving the usefulness of the lib
  * versions.
  *
183117fe
  * @{
  */
 
9cde41cd
 #define AV_VERSION_INT(a, b, c) ((a)<<16 | (b)<<8 | (c))
183117fe
 #define AV_VERSION_DOT(a, b, c) a ##.## b ##.## c
 #define AV_VERSION(a, b, c) AV_VERSION_DOT(a, b, c)
 
 /**
21c34cb2
  * Extract version components from the full ::AV_VERSION_INT int as returned
  * by functions like ::avformat_version() and ::avcodec_version()
  */
 #define AV_VERSION_MAJOR(a) ((a) >> 16)
 #define AV_VERSION_MINOR(a) (((a) & 0x00FF00) >> 8)
 #define AV_VERSION_MICRO(a) ((a) & 0xFF)
 
 /**
183117fe
  * @}
  */
 
86ab7b0f
 /**
c41899a3
  * @defgroup lavu_ver Version and Build diagnostics
  *
  * Macros and function useful to check at compiletime and at runtime
  * which version of libavutil is in use.
  *
  * @{
  */
 
69b5ce64
 #define LIBAVUTIL_VERSION_MAJOR  56
d268094f
 #define LIBAVUTIL_VERSION_MINOR   4
e1de9eab
 #define LIBAVUTIL_VERSION_MICRO 100
c41899a3
 
 #define LIBAVUTIL_VERSION_INT   AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
                                                LIBAVUTIL_VERSION_MINOR, \
                                                LIBAVUTIL_VERSION_MICRO)
 #define LIBAVUTIL_VERSION       AV_VERSION(LIBAVUTIL_VERSION_MAJOR,     \
                                            LIBAVUTIL_VERSION_MINOR,     \
                                            LIBAVUTIL_VERSION_MICRO)
 #define LIBAVUTIL_BUILD         LIBAVUTIL_VERSION_INT
 
 #define LIBAVUTIL_IDENT         "Lavu" AV_STRINGIFY(LIBAVUTIL_VERSION)
 
 /**
58c7bf78
  * @defgroup lavu_depr_guards Deprecation Guards
2047e40e
  * FF_API_* defines may be placed below to indicate public API that will be
  * dropped at a future version bump. The defines themselves are not part of
  * the public API and may change, break or disappear at any time.
86ab7b0f
  *
0aa9bbbc
  * @note, when bumping the major version it is recommended to manually
0b782990
  * disable each FF_API_* in its own commit instead of disabling them all
0aa9bbbc
  * at once through the bump. This improves the git bisect-ability of the change.
0b782990
  *
86ab7b0f
  * @{
c41899a3
  */
 
9f8e57ef
 #ifndef FF_API_VAAPI
69b5ce64
 #define FF_API_VAAPI                    (LIBAVUTIL_VERSION_MAJOR < 57)
9f8e57ef
 #endif
a9915268
 #ifndef FF_API_FRAME_QP
69b5ce64
 #define FF_API_FRAME_QP                 (LIBAVUTIL_VERSION_MAJOR < 57)
a9915268
 #endif
2268db2c
 #ifndef FF_API_PLUS1_MINUS1
69b5ce64
 #define FF_API_PLUS1_MINUS1             (LIBAVUTIL_VERSION_MAJOR < 57)
2268db2c
 #endif
1aa24df7
 #ifndef FF_API_ERROR_FRAME
69b5ce64
 #define FF_API_ERROR_FRAME              (LIBAVUTIL_VERSION_MAJOR < 57)
1aa24df7
 #endif
32c83590
 #ifndef FF_API_PKT_PTS
07a2b155
 #define FF_API_PKT_PTS                  (LIBAVUTIL_VERSION_MAJOR < 57)
32c83590
 #endif
e435beb1
 #ifndef FF_API_CRYPTO_SIZE_T
07a2b155
 #define FF_API_CRYPTO_SIZE_T            (LIBAVUTIL_VERSION_MAJOR < 57)
e435beb1
 #endif
7df37dd3
 #ifndef FF_API_FRAME_GET_SET
 #define FF_API_FRAME_GET_SET            (LIBAVUTIL_VERSION_MAJOR < 57)
 #endif
8c02adc6
 
 
86ab7b0f
 /**
  * @}
58c7bf78
  * @}
86ab7b0f
  */
 
 #endif /* AVUTIL_VERSION_H */