VirtualBox

source: vbox/trunk/include/VBox/version.h@ 52664

Last change on this file since 52664 was 44528, checked in by vboxsync, 12 years ago

header (C) fixes

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.3 KB
Line 
1/** @file
2 * VBox Version Management.
3 */
4
5/*
6 * Copyright (C) 2006-2011 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___VBox_version_h
27#define ___VBox_version_h
28
29/* Product info. */
30#include <product-generated.h>
31
32#ifndef RC_INVOKED
33# include <version-generated.h>
34
35/** Combined version number. */
36# define VBOX_VERSION (VBOX_VERSION_MAJOR << 16 | VBOX_VERSION_MINOR)
37/** Get minor version from combined version. */
38# define VBOX_GET_VERSION_MINOR(uVer) ((uVer) & 0xffff)
39/** Get major version from combined version. */
40# define VBOX_GET_VERSION_MAJOR(uVer) ((uVer) >> 16)
41
42/**
43 * Make a full version number.
44 *
45 * The returned number can be used in normal integer comparsions and will yield
46 * the expected results.
47 *
48 * @param uMajor The major version number.
49 * @param uMinor The minor version number.
50 * @param uBuild The build number.
51 * @returns Full version number.
52 */
53# define VBOX_FULL_VERSION_MAKE(uMajor, uMinor, uBuild) \
54 ( (uint32_t)((uMajor) & 0xff) << 24 \
55 | (uint32_t)((uMinor) & 0xff) << 16 \
56 | (uint32_t)((uBuild) & 0xffff) \
57 )
58
59/** Combined version number. */
60# define VBOX_FULL_VERSION \
61 VBOX_FULL_VERSION_MAKE(VBOX_VERSION_MAJOR, VBOX_VERSION_MINOR, VBOX_VERSION_BUILD)
62/** Get the major version number from a VBOX_FULL_VERSION style number. */
63# define VBOX_FULL_VERSION_GET_MAJOR(uFullVer) ( ((uFullVer) >> 24) & 0xffU )
64/** Get the minor version number from a VBOX_FULL_VERSION style number. */
65# define VBOX_FULL_VERSION_GET_MINOR(uFullVer) ( ((uFullVer) >> 16) & 0xffU )
66/** Get the build version number from a VBOX_FULL_VERSION style number. */
67# define VBOX_FULL_VERSION_GET_BUILD(uFullVer) ( ((uFullVer) ) & 0xffffU )
68
69/**
70 * Make a short version number for use in 16 bit version fields.
71 *
72 * The returned number can be used in normal integer comparsions and will yield
73 * the expected results.
74 *
75 * @param uMajor The major version number.
76 * @param uMinor The minor version number.
77 * @returns Short version number.
78 */
79# define VBOX_SHORT_VERSION_MAKE(uMajor, uMinor) \
80 ( (uint16_t)((uMajor) & 0xff) << 8 \
81 | (uint16_t)((uMinor) & 0xff) \
82 )
83
84/** Combined short version number. */
85# define VBOX_SHORT_VERSION \
86 VBOX_SHORT_VERSION_MAKE(VBOX_VERSION_MAJOR, VBOX_VERSION_MINOR)
87/** Get the major version number from a VBOX_SHORT_VERSION style number. */
88# define VBOX_SHORT_VERSION_GET_MAJOR(uShortVer) ( ((uShortVer) >> 8) & 0xffU )
89/** Get the minor version number from a VBOX_SHORT_VERSION style number. */
90# define VBOX_SHORT_VERSION_GET_MINOR(uShortVer) ( (uShortVer) & 0xffU )
91
92#endif /* !RC_INVOKED */
93
94/** @name Prefined strings for Windows resource files
95 *
96 * @remarks The VBOX_VERSION_*_NR define are integer numbers while
97 * VBOX_VERSION_* are strings when using the resource compile.
98 * Kind of confusing...
99 *
100 * @{ */
101#define VBOX_RC_COMPANY_NAME VBOX_VENDOR
102#define VBOX_RC_LEGAL_COPYRIGHT "Copyright (C) 2009-" VBOX_C_YEAR " Oracle Corporation\0"
103#define VBOX_RC_PRODUCT_VERSION VBOX_VERSION_MAJOR_NR , VBOX_VERSION_MINOR_NR , 0 , 0
104#define VBOX_RC_FILE_VERSION VBOX_VERSION_MAJOR_NR , VBOX_VERSION_MINOR_NR , 0 , 0
105/** @} */
106
107/** @todo Clean up the resource compiler mess where we cannot include
108 * version-generated.h and requires two files. */
109
110#endif
111
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle
ContactPrivacy/Do Not Sell My InfoTerms of Use