/* * Clutter. * * An OpenGL based 'interactive canvas' library. * * Authored By Matthew Allum * * Copyright (C) 2006 OpenedHand * * This library 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 of the License, or (at your option) any later version. * * This library 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 this library. If not, see . * * */ #if !defined(__CLUTTER_H_INSIDE__) && !defined(CLUTTER_COMPILATION) #error "Only can be included directly." #endif #ifndef __CLUTTER_VERSION_H__ #define __CLUTTER_VERSION_H__ /** * SECTION:clutter-version * @short_description: Versioning utility macros * * Clutter offers a set of macros for checking the version of the library * at compile time; it also provides a function to perform the same check * at run time. * * Clutter adds version information to both API deprecations and additions; * by definining the macros %CLUTTER_VERSION_MIN_REQUIRED and * %CLUTTER_VERSION_MAX_ALLOWED, you can specify the range of Clutter versions * whose API you want to use. Functions that were deprecated before, or * introduced after, this range will trigger compiler warnings. For instance, * if we define the following symbols: * * |[ * CLUTTER_VERSION_MIN_REQUIRED = CLUTTER_VERSION_1_6 * CLUTTER_VERSION_MAX_ALLOWED = CLUTTER_VERSION_1_8 * ]| * * and we have the following functions annotated in the Clutter headers: * * |[ * void clutter_function_A (void) CLUTTER_DEPRECATED_IN_1_4; * void clutter_function_B (void) CLUTTER_DEPRECATED_IN_1_6; * void clutter_function_C (void) CLUTTER_AVAILABLE_IN_1_8; * void clutter_function_D (void) CLUTTER_AVAILABLE_IN_1_10; * ]| * * then any application code using the functions above will get the output: * * |[ * clutter_function_A: deprecation warning * clutter_function_B: no warning * clutter_function_C: no warning * clutter_function_D: symbol not available warning * ]| * * It is possible to disable the compiler warnings by defining the macro * %CLUTTER_DISABLE_DEPRECATION_WARNINGS before including the clutter.h * header. */ #include G_BEGIN_DECLS /** * CLUTTER_MAJOR_VERSION: * * The major version of the Clutter library (1, if %CLUTTER_VERSION is 1.2.3) */ #define CLUTTER_MAJOR_VERSION (@CLUTTER_MAJOR_VERSION@) /** * CLUTTER_MINOR_VERSION: * * The minor version of the Clutter library (2, if %CLUTTER_VERSION is 1.2.3) */ #define CLUTTER_MINOR_VERSION (@CLUTTER_MINOR_VERSION@) /** * CLUTTER_MICRO_VERSION: * * The micro version of the Clutter library (3, if %CLUTTER_VERSION is 1.2.3) */ #define CLUTTER_MICRO_VERSION (@CLUTTER_MICRO_VERSION@) /** * CLUTTER_VERSION_S: * * The full version of the Clutter library, in string form (suited for * string concatenation) */ #define CLUTTER_VERSION_S "@CLUTTER_VERSION@" /** * CLUTTER_VERSION: * * Numerically encoded version of the Clutter library, like 0x010203 */ #define CLUTTER_VERSION ((CLUTTER_MAJOR_VERSION << 24) | \ (CLUTTER_MINOR_VERSION << 16) | \ (CLUTTER_MICRO_VERSION << 8)) /* XXX - Every new stable minor release bump should add a macro here */ /** * CLUTTER_VERSION_2_0: * * A macro that evaluates to the 1.0 version of Clutter, in a format * that can be used by the C pre-processor. */ #define CLUTTER_VERSION_2_0 (G_ENCODE_VERSION (2, 0)) /* evaluates to the current stable version; for development cycles, * this means the next stable target */ #if (CLUTTER_MINOR_VERSION % 2) # define CLUTTER_VERSION_CUR_STABLE (G_ENCODE_VERSION (CLUTTER_MAJOR_VERSION, CLUTTER_MINOR_VERSION + 1)) #else # define CLUTTER_VERSION_CUR_STABLE (G_ENCODE_VERSION (CLUTTER_MAJOR_VERSION, CLUTTER_MINOR_VERSION)) #endif /* evaluates to the previous stable version */ #if (CLUTTER_MINOR_VERSION % 2) # define CLUTTER_VERSION_PREV_STABLE (G_ENCODE_VERSION (CLUTTER_MAJOR_VERSION, CLUTTER_MINOR_VERSION - 1)) #else # define CLUTTER_VERSION_PREV_STABLE (G_ENCODE_VERSION (CLUTTER_MAJOR_VERSION, CLUTTER_MINOR_VERSION - 2)) #endif /** * CLUTTER_CHECK_VERSION: * @major: major version, like 1 in 1.2.3 * @minor: minor version, like 2 in 1.2.3 * @micro: micro version, like 3 in 1.2.3 * * Evaluates to %TRUE if the version of the Clutter library is greater * than @major, @minor and @micro */ #define CLUTTER_CHECK_VERSION(major,minor,micro) \ (CLUTTER_MAJOR_VERSION > (major) || \ (CLUTTER_MAJOR_VERSION == (major) && CLUTTER_MINOR_VERSION > (minor)) || \ (CLUTTER_MAJOR_VERSION == (major) && CLUTTER_MINOR_VERSION == (minor) && CLUTTER_MICRO_VERSION >= (micro))) gboolean clutter_check_version (guint major, guint minor, guint micro); gboolean clutter_check_windowing_backend (const char *backend_type); G_END_DECLS #endif /* __CLUTTER_VERSION_H__ */