2006-12-27 18:19:34 +00:00
|
|
|
/*
|
|
|
|
* Clutter.
|
|
|
|
*
|
|
|
|
* An OpenGL based 'interactive canvas' library.
|
|
|
|
*
|
|
|
|
* Authored By Matthew Allum <mallum@openedhand.com>
|
|
|
|
*
|
|
|
|
* 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
|
2010-03-01 12:56:10 +00:00
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*
|
2006-12-27 18:19:34 +00:00
|
|
|
*/
|
|
|
|
|
2007-08-07 14:03:30 +00:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2006-11-20 12:02:24 +00:00
|
|
|
#ifndef __CLUTTER_VERSION_H__
|
|
|
|
#define __CLUTTER_VERSION_H__
|
|
|
|
|
2009-10-30 11:02:35 +00:00
|
|
|
#include <glib.h>
|
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
2007-08-07 14:03:30 +00:00
|
|
|
/**
|
|
|
|
* CLUTTER_MAJOR_VERSION:
|
|
|
|
*
|
|
|
|
* The major version of the Clutter library (1, if %CLUTTER_VERSION is 1.2.3)
|
|
|
|
*/
|
2007-08-19 17:06:41 +00:00
|
|
|
#define CLUTTER_MAJOR_VERSION (@CLUTTER_MAJOR_VERSION@)
|
2007-08-07 14:03:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CLUTTER_MINOR_VERSION:
|
|
|
|
*
|
|
|
|
* The minor version of the Clutter library (2, if %CLUTTER_VERSION is 1.2.3)
|
|
|
|
*/
|
2007-08-19 17:06:41 +00:00
|
|
|
#define CLUTTER_MINOR_VERSION (@CLUTTER_MINOR_VERSION@)
|
2007-08-07 14:03:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CLUTTER_MICRO_VERSION:
|
|
|
|
*
|
|
|
|
* The micro version of the Clutter library (3, if %CLUTTER_VERSION is 1.2.3)
|
|
|
|
*/
|
2007-08-19 17:06:41 +00:00
|
|
|
#define CLUTTER_MICRO_VERSION (@CLUTTER_MICRO_VERSION@)
|
2006-11-20 12:02:24 +00:00
|
|
|
|
2007-08-07 14:03:30 +00:00
|
|
|
/**
|
|
|
|
* CLUTTER_VERSION:
|
|
|
|
*
|
|
|
|
* The full version of the Clutter library, like 1.2.3
|
|
|
|
*/
|
2006-11-20 12:02:24 +00:00
|
|
|
#define CLUTTER_VERSION @CLUTTER_VERSION@
|
2007-08-07 14:03:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CLUTTER_VERSION_S:
|
|
|
|
*
|
|
|
|
* The full version of the Clutter library, in string form (suited for
|
|
|
|
* string concatenation)
|
|
|
|
*/
|
2006-11-20 12:02:24 +00:00
|
|
|
#define CLUTTER_VERSION_S "@CLUTTER_VERSION@"
|
2007-08-07 14:03:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* CLUTTER_VERSION_HEX:
|
|
|
|
*
|
|
|
|
* Numerically encoded version of the Clutter library, like 0x010203
|
|
|
|
*/
|
2006-12-08 16:12:52 +00:00
|
|
|
#define CLUTTER_VERSION_HEX ((CLUTTER_MAJOR_VERSION << 24) | \
|
|
|
|
(CLUTTER_MINOR_VERSION << 16) | \
|
|
|
|
(CLUTTER_MICRO_VERSION << 8))
|
2006-11-20 12:02:24 +00:00
|
|
|
|
2007-08-07 14:03:30 +00:00
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
2006-11-20 12:02:24 +00:00
|
|
|
#define CLUTTER_CHECK_VERSION(major,minor,micro) \
|
2006-12-02 22:54:58 +00:00
|
|
|
(CLUTTER_MAJOR_VERSION > (major) || \
|
2006-11-20 12:02:24 +00:00
|
|
|
(CLUTTER_MAJOR_VERSION == (major) && CLUTTER_MINOR_VERSION > (minor)) || \
|
2007-08-20 11:54:28 +00:00
|
|
|
(CLUTTER_MAJOR_VERSION == (major) && CLUTTER_MINOR_VERSION == (minor) && CLUTTER_MICRO_VERSION >= (micro)))
|
2006-11-20 12:02:24 +00:00
|
|
|
|
2007-08-07 14:03:30 +00:00
|
|
|
/**
|
|
|
|
* CLUTTER_FLAVOUR:
|
|
|
|
*
|
|
|
|
* GL Windowing system used
|
|
|
|
*
|
|
|
|
* Since: 0.4
|
2011-09-21 18:05:03 +01:00
|
|
|
*
|
|
|
|
* 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.
|
2007-08-07 14:03:30 +00:00
|
|
|
*/
|
2007-03-22 18:21:59 +00:00
|
|
|
#define CLUTTER_FLAVOUR "@CLUTTER_FLAVOUR@"
|
2007-02-13 23:31:57 +00:00
|
|
|
|
2007-08-07 14:03:30 +00:00
|
|
|
/**
|
|
|
|
* CLUTTER_COGL
|
|
|
|
*
|
|
|
|
* Cogl (internal GL abstraction utility library) backend. Can be "gl" or
|
|
|
|
* "gles" currently
|
|
|
|
*
|
|
|
|
* Since: 0.4
|
2011-09-21 18:05:03 +01:00
|
|
|
*
|
|
|
|
* Deprecated: 1.10: The macro evaluates to "deprecated" as Cogl can be
|
|
|
|
* compiled against multiple GL implementations.
|
2007-08-07 14:03:30 +00:00
|
|
|
*/
|
2007-05-14 09:11:23 +00:00
|
|
|
#define CLUTTER_COGL "@CLUTTER_COGL@"
|
|
|
|
|
2008-03-31 17:15:02 +00:00
|
|
|
/**
|
|
|
|
* CLUTTER_STAGE_TYPE:
|
|
|
|
*
|
|
|
|
* The default GObject type for the Clutter stage.
|
|
|
|
*
|
2009-10-30 11:02:35 +00:00
|
|
|
* Since: 0.8
|
2011-09-21 18:05:03 +01:00
|
|
|
*
|
|
|
|
* 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.
|
2008-03-31 17:15:02 +00:00
|
|
|
*/
|
|
|
|
#define CLUTTER_STAGE_TYPE @CLUTTER_STAGE_TYPE@
|
|
|
|
|
2007-08-07 14:03:30 +00:00
|
|
|
/**
|
|
|
|
* CLUTTER_NO_FPU:
|
|
|
|
*
|
|
|
|
* Set to 1 if Clutter was built without FPU (i.e fixed math), 0 otherwise
|
|
|
|
*
|
2008-02-15 13:04:33 +00:00
|
|
|
* @Deprecated: 0.6: This macro is no longer defined (identical code is used
|
|
|
|
* regardless the presence of FPU).
|
2007-08-07 14:03:30 +00:00
|
|
|
*/
|
2008-02-15 13:04:33 +00:00
|
|
|
#define CLUTTER_NO_FPU CLUTTER_NO_FPU_MACRO_WAS_REMOVED
|
2007-05-14 09:11:23 +00:00
|
|
|
|
2010-03-02 09:53:55 +00:00
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
2009-10-30 11:02:35 +00:00
|
|
|
extern const guint clutter_major_version;
|
2010-03-02 09:53:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
2009-10-30 11:02:35 +00:00
|
|
|
extern const guint clutter_minor_version;
|
2010-03-02 09:53:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
2009-10-30 11:02:35 +00:00
|
|
|
extern const guint clutter_micro_version;
|
|
|
|
|
|
|
|
gboolean clutter_check_version (guint major,
|
|
|
|
guint minor,
|
|
|
|
guint micro);
|
|
|
|
|
2011-10-17 16:03:19 +01:00
|
|
|
gboolean clutter_check_windowing_backend (const char *backend_type);
|
2011-09-26 13:14:26 +01:00
|
|
|
|
2009-10-30 11:02:35 +00:00
|
|
|
G_END_DECLS
|
2008-03-31 17:15:02 +00:00
|
|
|
|
2006-11-20 12:02:24 +00:00
|
|
|
#endif /* __CLUTTER_VERSION_H__ */
|