/* * 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 . * * */ /** * SECTION:clutter-version * @short_description: Versioning utility macros * * Clutter offers a set of macros for checking the version of the library * an application was linked to. */ #ifndef __CLUTTER_VERSION_H__ #define __CLUTTER_VERSION_H__ #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: * * The full version of the Clutter library, like 1.2.3 */ #define CLUTTER_VERSION @CLUTTER_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_HEX: * * Numerically encoded version of the Clutter library, like 0x010203 */ #define CLUTTER_VERSION_HEX ((CLUTTER_MAJOR_VERSION << 24) | \ (CLUTTER_MINOR_VERSION << 16) | \ (CLUTTER_MICRO_VERSION << 8)) /** * 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))) /** * CLUTTER_FLAVOUR: * * GL Windowing system used * * Since: 0.4 * * Deprecated: 1.10: The macro evaluates to "deprecated" as Clutter can be * compiled with multiple windowing system backends. Use the various * CLUTTER_WINDOWING_* macros to detect the windowing system that Clutter * is being compiled against, and the type check macros for the * #ClutterBackend for a run-time check. */ #define CLUTTER_FLAVOUR "@CLUTTER_FLAVOUR@" /** * CLUTTER_COGL * * Cogl (internal GL abstraction utility library) backend. Can be "gl" or * "gles" currently * * Since: 0.4 * * Deprecated: 1.10: The macro evaluates to "deprecated" as Cogl can be * compiled against multiple GL implementations. */ #define CLUTTER_COGL "@CLUTTER_COGL@" /** * CLUTTER_STAGE_TYPE: * * The default GObject type for the Clutter stage. * * Since: 0.8 * * Deprecated: 1.10: The macro evaluates to "deprecated" as Clutter can * be compiled against multiple windowing systems. You can use the * CLUTTER_WINDOWING_* macros for compile-time checks, and the type * check macros for run-time checks. */ #define CLUTTER_STAGE_TYPE @CLUTTER_STAGE_TYPE@ /** * CLUTTER_NO_FPU: * * Set to 1 if Clutter was built without FPU (i.e fixed math), 0 otherwise * * @Deprecated: 0.6: This macro is no longer defined (identical code is used * regardless the presence of FPU). */ #define CLUTTER_NO_FPU CLUTTER_NO_FPU_MACRO_WAS_REMOVED /** * clutter_major_version: * * The major component of the Clutter library version, e.g. 1 if the version * is 1.2.3 * * This value can be used for run-time version checks * * For a compile-time check, use %CLUTTER_MAJOR_VERSION * * Since: 1.2 */ extern const guint clutter_major_version; /** * clutter_minor_version: * * The minor component of the Clutter library version, e.g. 2 if the version * is 1.2.3 * * This value can be used for run-time version checks * * For a compile-time check, use %CLUTTER_MINOR_VERSION * * Since: 1.2 */ extern const guint clutter_minor_version; /** * clutter_micro_version: * * The micro component of the Clutter library version, e.g. 3 if the version * is 1.2.3 * * This value can be used for run-time version checks * * For a compile-time check, use %CLUTTER_MICRO_VERSION * * Since: 1.2 */ extern const guint clutter_micro_version; gboolean clutter_check_version (guint major, guint minor, guint micro); G_END_DECLS #endif /* __CLUTTER_VERSION_H__ */