- bin/pack_src.sh
+ mpkg_src.sh
* Moved and renamed to align with rest of pkg creation scripts.
(this should also go to package dir once in the future)
* source/common/hbver.c
* Converted decimal version numbers to hex in BCC guards.
+ Added BCC version detections for old (pre-5.x) versions.
(Borrowed from xhb/Miguel Angel Marchuet)
748 lines
20 KiB
C
748 lines
20 KiB
C
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* Harbour Project source code:
|
|
* Version detection functions
|
|
*
|
|
* Copyright 1999 {list of individual authors and e-mail addresses}
|
|
* www - http://www.harbour-project.org
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This program 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 General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this software; see the file COPYING. If not, write to
|
|
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
|
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
|
*
|
|
* As a special exception, the Harbour Project gives permission for
|
|
* additional uses of the text contained in its release of Harbour.
|
|
*
|
|
* The exception is that, if you link the Harbour libraries with other
|
|
* files to produce an executable, this does not by itself cause the
|
|
* resulting executable to be covered by the GNU General Public License.
|
|
* Your use of that executable is in no way restricted on account of
|
|
* linking the Harbour library code into it.
|
|
*
|
|
* This exception does not however invalidate any other reasons why
|
|
* the executable file might be covered by the GNU General Public License.
|
|
*
|
|
* This exception applies only to the code released by the Harbour
|
|
* Project under the name Harbour. If you copy code from other
|
|
* Harbour Project or Free Software Foundation releases into a copy of
|
|
* Harbour, as the General Public License permits, the exception does
|
|
* not apply to the code that you add in this way. To avoid misleading
|
|
* anyone as to the status of such modified files, you must delete
|
|
* this exception notice from them.
|
|
*
|
|
* If you write modifications of your own for Harbour, it is your choice
|
|
* whether to permit this exception to apply to your modifications.
|
|
* If you do not wish that, delete this exception notice.
|
|
*
|
|
*/
|
|
|
|
/*
|
|
* The following parts are Copyright of the individual authors.
|
|
* www - http://www.harbour-project.org
|
|
*
|
|
* Copyright 1999 Luiz Rafael Culik <culik@sl.conex.net>
|
|
* hb_verPlatform() (support for determining the Windows version)
|
|
*
|
|
* Copyright 1999 Jose Lalin <dezac@corevia.com>
|
|
* hb_verPlatform() (support for determining many Windows flavours)
|
|
* hb_verCompiler() (support for determining some compiler version/revision)
|
|
*
|
|
* Copyright 2000-2009 Viktor Szakats (harbour.01 syenar.hu)
|
|
* hb_verCPU()
|
|
* hb_verPlatform() (support for detecting Windows NT on DOS)
|
|
* hb_verPlatform() (rearrangment and cleanup)
|
|
* hb_verPlatform() (Wine detection and some more)
|
|
*
|
|
* See COPYING for licensing terms.
|
|
*
|
|
*/
|
|
|
|
/* NOTE: For OS/2. Must be ahead of any and all #include statements */
|
|
#define INCL_DOSMISC
|
|
|
|
#define HB_OS_WIN_USED
|
|
|
|
#include "hbapi.h"
|
|
#include "hbmemory.ch"
|
|
|
|
#if defined( HB_OS_WIN )
|
|
|
|
#ifndef VER_PLATFORM_WIN32_WINDOWS
|
|
#define VER_PLATFORM_WIN32_WINDOWS 1
|
|
#endif
|
|
#ifndef VER_PLATFORM_WIN32_CE
|
|
#define VER_PLATFORM_WIN32_CE 3
|
|
#endif
|
|
|
|
#elif defined( HB_OS_UNIX ) && !defined( __CEGCC__ )
|
|
|
|
#include <sys/utsname.h>
|
|
|
|
#endif
|
|
|
|
const char * hb_verCPU( void )
|
|
{
|
|
HB_TRACE(HB_TR_DEBUG, ("hb_verCPU()"));
|
|
|
|
#if defined( HB_CPU_X86 )
|
|
return "x86";
|
|
#elif defined( HB_CPU_X86_64 )
|
|
return "x86-64";
|
|
#elif defined( HB_CPU_IA_64 )
|
|
return "IA-64";
|
|
#elif defined( HB_CPU_PPC )
|
|
return "PPC";
|
|
#elif defined( HB_CPU_PPC_64 )
|
|
return "PPC64";
|
|
#elif defined( HB_CPU_SPARC )
|
|
return "Sparc/32";
|
|
#elif defined( HB_CPU_SPARC_64 )
|
|
return "Sparc/64";
|
|
#elif defined( HB_CPU_ARM )
|
|
return "ARM";
|
|
#elif defined( HB_CPU_MIPS )
|
|
return "MIPS";
|
|
#elif defined( HB_CPU_SH )
|
|
return "SuperH";
|
|
#elif defined( HB_CPU_ZARCH )
|
|
return "z/Architecture";
|
|
#elif defined( HB_CPU_PARISC )
|
|
return "PA-RISC";
|
|
#elif defined( HB_CPU_ALPHA )
|
|
return "Alpha";
|
|
#elif defined( HB_CPU_POWER )
|
|
return "POWER";
|
|
#elif defined( HB_CPU_M68K )
|
|
return "m68k";
|
|
#elif defined( HB_CPU_SYS370 )
|
|
return "System/370";
|
|
#elif defined( HB_CPU_SYS390 )
|
|
return "System/390";
|
|
#else
|
|
return "(unknown)";
|
|
#endif
|
|
}
|
|
|
|
const char * hb_verHostCPU( void )
|
|
{
|
|
HB_TRACE(HB_TR_DEBUG, ("hb_verHostCPU()"));
|
|
|
|
/* TODO */
|
|
|
|
return "";
|
|
}
|
|
|
|
/* NOTE: OS() function, as a primary goal will detect the version number
|
|
of the target platform. As an extra it may also detect the host OS.
|
|
The latter is mainly an issue in DOS, where the host OS can be OS/2
|
|
WinNT/2K, Win3x, Win9x, DOSEMU, Desqview, etc. [vszakats] */
|
|
|
|
/* NOTE: The caller must free the returned buffer. [vszakats] */
|
|
|
|
/* NOTE: The first word of the returned string must describe
|
|
the OS family as used in __PLATFORM__*. Latter macro
|
|
will in fact be formed from the string returned
|
|
by this function. [vszakats] */
|
|
|
|
/* NOTE: Must be larger than 128, which is the maximum size of
|
|
osVer.szCSDVersion (Windows). [vszakats] */
|
|
#define PLATFORM_BUF_SIZE 255
|
|
|
|
char * hb_verPlatform( void )
|
|
{
|
|
char * pszPlatform;
|
|
|
|
HB_TRACE(HB_TR_DEBUG, ("hb_verPlatform()"));
|
|
|
|
pszPlatform = ( char * ) hb_xgrab( PLATFORM_BUF_SIZE + 1 );
|
|
|
|
#if defined( HB_OS_DOS )
|
|
|
|
{
|
|
union REGS regs;
|
|
|
|
regs.h.ah = 0x30;
|
|
HB_DOS_INT86( 0x21, ®s, ®s );
|
|
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "DOS %d.%02d", regs.h.al, regs.h.ah );
|
|
|
|
/* Host OS detection: Windows 2.x, 3.x, 95/98 */
|
|
|
|
{
|
|
regs.HB_XREGS.ax = 0x1600;
|
|
HB_DOS_INT86( 0x2F, ®s, ®s );
|
|
|
|
if( regs.h.al != 0x00 && regs.h.al != 0x80 )
|
|
{
|
|
char szHost[ 128 ];
|
|
|
|
if( regs.h.al == 0x01 || regs.h.al == 0xFF )
|
|
hb_snprintf( szHost, sizeof( szHost ), " (Windows 2.x)" );
|
|
else
|
|
hb_snprintf( szHost, sizeof( szHost ), " (Windows %d.%02d)", regs.h.al, regs.h.ah );
|
|
|
|
hb_strncat( pszPlatform, szHost, PLATFORM_BUF_SIZE );
|
|
}
|
|
}
|
|
|
|
/* Host OS detection: Windows NT family */
|
|
|
|
{
|
|
regs.HB_XREGS.ax = 0x3306;
|
|
HB_DOS_INT86( 0x21, ®s, ®s );
|
|
|
|
if( regs.HB_XREGS.bx == 0x3205 )
|
|
hb_strncat( pszPlatform, " (Windows NT)", PLATFORM_BUF_SIZE );
|
|
}
|
|
|
|
/* Host OS detection: OS/2 */
|
|
|
|
{
|
|
regs.h.ah = 0x30;
|
|
HB_DOS_INT86( 0x21, ®s, ®s );
|
|
|
|
if( regs.h.al >= 10 )
|
|
{
|
|
char szHost[ 128 ];
|
|
|
|
if( regs.h.al == 20 && regs.h.ah > 20 )
|
|
hb_snprintf( szHost, sizeof( szHost ), " (OS/2 %d.%02d)", regs.h.ah / 10, regs.h.ah % 10 );
|
|
else
|
|
hb_snprintf( szHost, sizeof( szHost ), " (OS/2 %d.%02d)", regs.h.al / 10, regs.h.ah );
|
|
|
|
hb_strncat( pszPlatform, szHost, PLATFORM_BUF_SIZE );
|
|
}
|
|
}
|
|
}
|
|
|
|
#elif defined( HB_OS_OS2 )
|
|
|
|
{
|
|
unsigned long aulQSV[ QSV_MAX ] = { 0 };
|
|
APIRET rc;
|
|
|
|
rc = DosQuerySysInfo( 1L, QSV_MAX, ( void * ) aulQSV, sizeof( ULONG ) * QSV_MAX );
|
|
|
|
if( rc == 0 )
|
|
{
|
|
/* is this OS/2 2.x ? */
|
|
if( aulQSV[ QSV_VERSION_MINOR - 1 ] < 30 )
|
|
{
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "OS/2 %ld.%02ld",
|
|
aulQSV[ QSV_VERSION_MAJOR - 1 ] / 10,
|
|
aulQSV[ QSV_VERSION_MINOR - 1 ] );
|
|
}
|
|
else
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "OS/2 %2.2f",
|
|
( float ) aulQSV[ QSV_VERSION_MINOR - 1 ] / 10 );
|
|
}
|
|
else
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "OS/2" );
|
|
}
|
|
|
|
#elif defined( HB_OS_WIN )
|
|
|
|
{
|
|
OSVERSIONINFOA osVer;
|
|
|
|
osVer.dwOSVersionInfoSize = sizeof( osVer );
|
|
|
|
if( GetVersionExA( &osVer ) )
|
|
{
|
|
/* NOTE: Unofficial Wine detection.
|
|
http://www.mail-archive.com/wine-devel@winehq.org/msg48659.html */
|
|
HMODULE hntdll = GetModuleHandle( TEXT( "ntdll.dll" ) );
|
|
const char * pszWine = "";
|
|
const char * pszName = "";
|
|
|
|
if( hntdll )
|
|
{
|
|
#if defined( HB_OS_WIN_CE )
|
|
if( GetProcAddress( hntdll, TEXT( "wine_get_version" ) ) )
|
|
#else
|
|
if( GetProcAddress( hntdll, "wine_get_version" ) )
|
|
#endif
|
|
pszWine = " (Wine)";
|
|
}
|
|
|
|
switch( osVer.dwPlatformId )
|
|
{
|
|
case VER_PLATFORM_WIN32_WINDOWS:
|
|
|
|
if( osVer.dwMajorVersion == 4 && osVer.dwMinorVersion < 10 )
|
|
pszName = " 95";
|
|
else if( osVer.dwMajorVersion == 4 && osVer.dwMinorVersion == 10 )
|
|
pszName = " 98";
|
|
else
|
|
pszName = " ME";
|
|
|
|
break;
|
|
|
|
case VER_PLATFORM_WIN32_NT:
|
|
|
|
if( osVer.dwMajorVersion == 6 )
|
|
{
|
|
#if !defined( HB_OS_WIN_CE ) && !defined( __DMC__ ) && \
|
|
( !defined( _MSC_VER ) || _MSC_VER >= 1400 ) && \
|
|
defined( VER_NT_WORKSTATION )
|
|
OSVERSIONINFOEXA osVerEx;
|
|
|
|
osVerEx.dwOSVersionInfoSize = sizeof( osVerEx );
|
|
|
|
if( GetVersionExA( ( OSVERSIONINFOA * ) &osVerEx ) )
|
|
{
|
|
if( osVer.dwMinorVersion == 1 )
|
|
{
|
|
if( osVerEx.wProductType == VER_NT_WORKSTATION )
|
|
pszName = " 7";
|
|
else
|
|
pszName = " Server 2008 R2";
|
|
}
|
|
else if( osVer.dwMinorVersion == 0 )
|
|
{
|
|
if( osVerEx.wProductType == VER_NT_WORKSTATION )
|
|
pszName = " Vista";
|
|
else
|
|
pszName = " Server 2008";
|
|
}
|
|
else
|
|
pszName = "";
|
|
}
|
|
else
|
|
#endif
|
|
pszName = "";
|
|
}
|
|
else if( osVer.dwMajorVersion == 5 && osVer.dwMinorVersion >= 2 )
|
|
pszName = " Server 2003 / XP x64";
|
|
else if( osVer.dwMajorVersion == 5 && osVer.dwMinorVersion == 1 )
|
|
pszName = " XP";
|
|
else if( osVer.dwMajorVersion == 5 )
|
|
pszName = " 2000";
|
|
else
|
|
pszName = " NT";
|
|
|
|
break;
|
|
|
|
case VER_PLATFORM_WIN32s:
|
|
pszName = " 32s";
|
|
break;
|
|
|
|
case VER_PLATFORM_WIN32_CE:
|
|
pszName = " CE";
|
|
break;
|
|
}
|
|
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "Windows%s%s %lu.%lu.%04u",
|
|
pszName,
|
|
pszWine,
|
|
osVer.dwMajorVersion,
|
|
osVer.dwMinorVersion,
|
|
LOWORD( osVer.dwBuildNumber ) );
|
|
|
|
/* Add service pack/other info */
|
|
|
|
if( osVer.szCSDVersion )
|
|
{
|
|
int i;
|
|
|
|
/* Skip the leading spaces (Win95B, Win98) */
|
|
for( i = 0; osVer.szCSDVersion[ i ] != '\0' && HB_ISSPACE( ( int ) osVer.szCSDVersion[ i ] ); i++ ) {};
|
|
|
|
if( osVer.szCSDVersion[ i ] != '\0' )
|
|
{
|
|
hb_strncat( pszPlatform, " ", PLATFORM_BUF_SIZE );
|
|
hb_strncat( pszPlatform, osVer.szCSDVersion + i, PLATFORM_BUF_SIZE );
|
|
}
|
|
}
|
|
}
|
|
else
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "Windows" );
|
|
}
|
|
|
|
#elif defined( __CEGCC__ )
|
|
{
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "Windows CE" );
|
|
}
|
|
#elif defined( HB_OS_UNIX )
|
|
|
|
{
|
|
struct utsname un;
|
|
|
|
uname( &un );
|
|
hb_snprintf( pszPlatform, PLATFORM_BUF_SIZE + 1, "%s %s %s", un.sysname, un.release, un.machine );
|
|
}
|
|
|
|
#else
|
|
|
|
{
|
|
hb_strncpy( pszPlatform, "(unknown)", PLATFORM_BUF_SIZE );
|
|
}
|
|
|
|
#endif
|
|
|
|
return pszPlatform;
|
|
}
|
|
|
|
BOOL hb_iswinnt( void )
|
|
{
|
|
#if defined( HB_OS_WIN )
|
|
static BOOL s_fWinNT = FALSE;
|
|
static BOOL s_fInited = FALSE;
|
|
|
|
if( ! s_fInited )
|
|
{
|
|
OSVERSIONINFO osvi;
|
|
osvi.dwOSVersionInfoSize = sizeof( osvi );
|
|
if( GetVersionEx( &osvi ) )
|
|
s_fWinNT = osvi.dwPlatformId == VER_PLATFORM_WIN32_NT; /* && osvi.dwMajorVersion >= 4); */
|
|
s_fInited = TRUE;
|
|
}
|
|
return s_fWinNT;
|
|
#else
|
|
return FALSE;
|
|
#endif
|
|
}
|
|
|
|
BOOL hb_iswince( void )
|
|
{
|
|
#if defined( HB_OS_WIN_CE )
|
|
return TRUE;
|
|
#else
|
|
return FALSE;
|
|
#endif
|
|
}
|
|
|
|
/* NOTE: The caller must free the returned buffer. [vszakats] */
|
|
|
|
#define COMPILER_BUF_SIZE 80
|
|
|
|
char * hb_verCompiler( void )
|
|
{
|
|
char * pszCompiler;
|
|
const char * pszName;
|
|
char szSub[ 32 ];
|
|
int iVerMajor;
|
|
int iVerMinor;
|
|
int iVerPatch;
|
|
|
|
HB_TRACE(HB_TR_DEBUG, ("hb_verCompiler()"));
|
|
|
|
pszCompiler = ( char * ) hb_xgrab( COMPILER_BUF_SIZE );
|
|
szSub[ 0 ] = '\0';
|
|
|
|
#if defined( __IBMC__ ) || defined( __IBMCPP__ )
|
|
|
|
#if defined( __IBMC__ )
|
|
iVerMajor = __IBMC__;
|
|
#else
|
|
iVerMajor = __IBMCPP__;
|
|
#endif
|
|
|
|
if( iVerMajor >= 300 )
|
|
pszName = "IBM Visual Age C++";
|
|
else
|
|
pszName = "IBM C++";
|
|
|
|
iVerMajor /= 100;
|
|
iVerMinor = iVerMajor % 100;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __POCC__ )
|
|
|
|
pszName = "Pelles ISO C Compiler";
|
|
iVerMajor = __POCC__ / 100;
|
|
iVerMinor = __POCC__ % 100;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __XCC__ )
|
|
|
|
pszName = "Pelles ISO C Compiler (XCC)";
|
|
iVerMajor = __XCC__ / 100;
|
|
iVerMinor = __XCC__ % 100;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __LCC__ )
|
|
|
|
pszName = "Logiciels/Informatique lcc-win32";
|
|
iVerMajor = 0 /* __LCC__ / 100 */;
|
|
iVerMinor = 0 /* __LCC__ % 100 */;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __DMC__ )
|
|
|
|
pszName = __DMC_VERSION_STRING__;
|
|
iVerMajor = 0;
|
|
iVerMinor = 0;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __ICL )
|
|
|
|
pszName = "Intel(R) C";
|
|
|
|
#if defined( __cplusplus )
|
|
hb_strncpy( szSub, "++", sizeof( szSub ) - 1 );
|
|
#endif
|
|
|
|
iVerMajor = __ICL / 100;
|
|
iVerMinor = __ICL % 100;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __ICC )
|
|
|
|
pszName = "Intel(R) (ICC) C";
|
|
|
|
#if defined( __cplusplus )
|
|
hb_strncpy( szSub, "++", sizeof( szSub ) - 1 );
|
|
#endif
|
|
|
|
iVerMajor = __ICC / 100;
|
|
iVerMinor = __ICC % 100;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( _MSC_VER )
|
|
|
|
#if ( _MSC_VER >= 800 )
|
|
pszName = "Microsoft Visual C";
|
|
#else
|
|
pszName = "Microsoft C";
|
|
#endif
|
|
|
|
#if defined( __cplusplus )
|
|
hb_strncpy( szSub, "++", sizeof( szSub ) - 1 );
|
|
#endif
|
|
|
|
iVerMajor = _MSC_VER / 100;
|
|
iVerMinor = _MSC_VER % 100;
|
|
|
|
#if defined( _MSC_FULL_VER )
|
|
iVerPatch = _MSC_FULL_VER - ( _MSC_VER * 10000 );
|
|
#else
|
|
iVerPatch = 0;
|
|
#endif
|
|
|
|
#elif defined( __BORLANDC__ )
|
|
|
|
#if ( __BORLANDC__ >= 0x0590 ) /* Version 5.9 */
|
|
#if ( __BORLANDC__ >= 0x0620 ) /* Version 6.2 */
|
|
pszName = "Borland/Embarcadero C++";
|
|
#else
|
|
pszName = "Borland/CodeGear C++";
|
|
#endif
|
|
#else
|
|
pszName = "Borland C++";
|
|
#endif
|
|
#if ( __BORLANDC__ == 0x0400 ) /* Version 3.0 */
|
|
iVerMajor = 3;
|
|
iVerMinor = 0;
|
|
iVerPatch = 0;
|
|
#elif ( __BORLANDC__ == 0x0410 ) /* Version 3.1 */
|
|
iVerMajor = 3;
|
|
iVerMinor = 1;
|
|
iVerPatch = 0;
|
|
#elif ( __BORLANDC__ == 0x0452 ) /* Version 4.0 */
|
|
iVerMajor = 4;
|
|
iVerMinor = 0;
|
|
iVerPatch = 0;
|
|
#elif ( __BORLANDC__ == 0x0460 ) /* Version 4.5 */
|
|
iVerMajor = 4;
|
|
iVerMinor = 5;
|
|
iVerPatch = 0;
|
|
#elif ( __BORLANDC__ >= 0x0500 ) /* Version 5.x */
|
|
iVerMajor = __BORLANDC__ >> 8;
|
|
iVerMinor = ( __BORLANDC__ & 0xFF ) >> 4;
|
|
iVerPatch = __BORLANDC__ & 0xF;
|
|
#else /* Version 4.x */
|
|
iVerMajor = __BORLANDC__ >> 8;
|
|
iVerMinor = ( __BORLANDC__ - 1 & 0xFF ) >> 4;
|
|
iVerPatch = 0;
|
|
#endif
|
|
|
|
#elif defined( __TURBOC__ )
|
|
|
|
pszName = "Borland Turbo C";
|
|
iVerMajor = __TURBOC__ >> 8;
|
|
iVerMinor = __TURBOC__ & 0xFF;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __MPW__ )
|
|
|
|
pszName = "MPW C";
|
|
iVerMajor = __MPW__ / 100;
|
|
iVerMinor = __MPW__ % 100;
|
|
iVerPatch = 0;
|
|
|
|
#elif defined( __WATCOMC__ )
|
|
|
|
#if __WATCOMC__ < 1200
|
|
pszName = "Watcom C";
|
|
#else
|
|
pszName = "Open Watcom C";
|
|
#endif
|
|
|
|
#if defined( __cplusplus )
|
|
hb_strncpy( szSub, "++", sizeof( szSub ) - 1 );
|
|
#endif
|
|
|
|
iVerMajor = __WATCOMC__ / 100;
|
|
iVerMinor = __WATCOMC__ % 100;
|
|
|
|
#if defined( __WATCOM_REVISION__ )
|
|
iVerPatch = __WATCOM_REVISION__;
|
|
#else
|
|
iVerPatch = 0;
|
|
#endif
|
|
|
|
#elif defined( __GNUC__ )
|
|
|
|
#if defined( __DJGPP__ )
|
|
pszName = "Delorie GNU C";
|
|
#elif defined( __CYGWIN__ )
|
|
pszName = "Cygwin GNU C";
|
|
#elif defined( __MINGW32__ )
|
|
pszName = "MinGW GNU C";
|
|
#elif defined( __RSX32__ )
|
|
pszName = "EMX/RSXNT/DOS GNU C";
|
|
#elif defined( __RSXNT__ )
|
|
pszName = "EMX/RSXNT/Win32 GNU C";
|
|
#elif defined( __EMX__ )
|
|
pszName = "EMX GNU C";
|
|
#else
|
|
pszName = "GNU C";
|
|
#endif
|
|
|
|
#if defined( __cplusplus )
|
|
hb_strncpy( szSub, "++", sizeof( szSub ) - 1 );
|
|
#endif
|
|
|
|
iVerMajor = __GNUC__;
|
|
iVerMinor = __GNUC_MINOR__;
|
|
#if defined( __GNUC_PATCHLEVEL__ )
|
|
iVerPatch = __GNUC_PATCHLEVEL__;
|
|
#else
|
|
iVerPatch = 0;
|
|
#endif
|
|
|
|
#elif defined( __SUNPRO_C )
|
|
|
|
pszName = "Sun C";
|
|
#if __SUNPRO_C < 0x600
|
|
iVerMajor = __SUNPRO_C / 0x100;
|
|
iVerMinor = ( __SUNPRO_C & 0xff ) / 0x10;
|
|
iVerPatch = __SUNPRO_C & 0xf;
|
|
#else
|
|
/* Until someone at Sun somes up with a reliable way of identifying
|
|
Sun Studio releases >= about 11. */
|
|
iVerMajor = iVerMinor = iVerPatch = 0;
|
|
hb_snprintf( szSub, sizeof( szSub ) - 1, " (ident 0x%X)", __SUNPRO_C );
|
|
#endif
|
|
|
|
#elif defined( __SUNPRO_CC )
|
|
|
|
pszName = "Sun C++";
|
|
#if __SUNPRO_CC < 0x600
|
|
pszName = "Sun C++";
|
|
iVerMajor = __SUNPRO_CC / 0x100;
|
|
iVerMinor = ( __SUNPRO_CC & 0xff ) / 0x10;
|
|
iVerPatch = __SUNPRO_CC & 0xf;
|
|
#else
|
|
/* Until someone at Sun somes up with a reliable way of identifying
|
|
Sun Studio releases >= about 11. */
|
|
iVerMajor = iVerMinor = iVerPatch = 0;
|
|
hb_snprintf( szSub, sizeof( szSub ) - 1, " (ident 0x%X)", __SUNPRO_CC );
|
|
#endif
|
|
|
|
#else
|
|
|
|
pszName = ( char * ) NULL;
|
|
iVerMajor = iVerMinor = iVerPatch = 0;
|
|
|
|
#endif
|
|
|
|
if( pszName )
|
|
{
|
|
if( iVerPatch != 0 )
|
|
hb_snprintf( pszCompiler, COMPILER_BUF_SIZE, "%s%s %hd.%hd.%hd", pszName, szSub, iVerMajor, iVerMinor, iVerPatch );
|
|
else if( iVerMajor != 0 || iVerMinor != 0 )
|
|
hb_snprintf( pszCompiler, COMPILER_BUF_SIZE, "%s%s %hd.%hd", pszName, szSub, iVerMajor, iVerMinor );
|
|
else
|
|
hb_snprintf( pszCompiler, COMPILER_BUF_SIZE, "%s%s", pszName, szSub );
|
|
}
|
|
else
|
|
hb_strncpy( pszCompiler, "(unknown)", COMPILER_BUF_SIZE - 1 );
|
|
|
|
#if defined( __DJGPP__ )
|
|
hb_snprintf( szSub, sizeof( szSub ), " (DJGPP %i.%02i)", ( int ) __DJGPP__, ( int ) __DJGPP_MINOR__ );
|
|
hb_strncat( pszCompiler, szSub, COMPILER_BUF_SIZE - 1 );
|
|
#endif
|
|
|
|
#if defined( HB_ARCH_16BIT )
|
|
hb_strncat( pszCompiler, " (16-bit)", COMPILER_BUF_SIZE - 1 );
|
|
#elif defined( HB_ARCH_32BIT )
|
|
hb_strncat( pszCompiler, " (32-bit)", COMPILER_BUF_SIZE - 1 );
|
|
#elif defined( HB_ARCH_64BIT )
|
|
hb_strncat( pszCompiler, " (64-bit)", COMPILER_BUF_SIZE - 1 );
|
|
#endif
|
|
|
|
return pszCompiler;
|
|
}
|
|
|
|
/* NOTE: The caller must free the returned buffer. [vszakats] */
|
|
|
|
/* NOTE:
|
|
CA-Cl*pper 5.2e returns: "Clipper (R) 5.2e Intl. (x216) (1995.02.07)"
|
|
CA-Cl*pper 5.3b returns: "Clipper (R) 5.3b Intl. (Rev. 338) (1997.04.25)"
|
|
*/
|
|
|
|
char * hb_verHarbour( void )
|
|
{
|
|
char * pszVersion;
|
|
|
|
HB_TRACE(HB_TR_DEBUG, ("hb_verHarbour()"));
|
|
|
|
pszVersion = ( char * ) hb_xgrab( 80 );
|
|
hb_snprintf( pszVersion, 80, "Harbour %d.%d.%d%s (Rev. %d)",
|
|
HB_VER_MAJOR, HB_VER_MINOR, HB_VER_RELEASE, HB_VER_STATUS,
|
|
hb_verSvnID() );
|
|
|
|
return pszVersion;
|
|
}
|
|
|
|
char * hb_verPCode( void )
|
|
{
|
|
char * pszPCode;
|
|
|
|
HB_TRACE(HB_TR_DEBUG, ("hb_verPCode()"));
|
|
|
|
pszPCode = ( char * ) hb_xgrab( 24 );
|
|
hb_snprintf( pszPCode, 24, "PCode version: %d.%d",
|
|
HB_PCODE_VER >> 8, HB_PCODE_VER & 0xFF );
|
|
|
|
return pszPCode;
|
|
}
|
|
|
|
char * hb_verBuildDate( void )
|
|
{
|
|
char * pszDate;
|
|
|
|
HB_TRACE(HB_TR_DEBUG, ("hb_verBuildDate()"));
|
|
|
|
pszDate = ( char * ) hb_xgrab( 64 );
|
|
hb_snprintf( pszDate, 64, "%s %s", __DATE__, __TIME__ );
|
|
|
|
return pszDate;
|
|
}
|