perfsrv/analyzetool/commandlineengine/src/version.cpp
author hgs
Mon, 06 Sep 2010 15:00:47 +0300
changeset 51 98307c651589
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Show / Check atool version.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
#include "../inc/ATCommonDefines.h"
hgs
parents:
diff changeset
    18
#include "../inc/CATBase.h"
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
//Function declarations.
hgs
parents:
diff changeset
    21
int showVersionInfo( void );
hgs
parents:
diff changeset
    22
int showCoreVersionInfo( void );
hgs
parents:
diff changeset
    23
bool readCoreVersionInfo( const string& sFile, string& sVersion );
hgs
parents:
diff changeset
    24
string findAnalyzeToolHeader( void );
hgs
parents:
diff changeset
    25
int showDbgHelpVersionInfo( bool showVersion );
hgs
parents:
diff changeset
    26
int getDllVersion( LPCTSTR libName, WORD *majorVersion, WORD *minorVersion, WORD *buildNumber, WORD *revisionNumber );
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
//External GetEpocRoot function
hgs
parents:
diff changeset
    29
extern bool GetEpocRoot( string &sEpocRoot );
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
void convertWriteTimeToLocalTime( FILETIME ftWrite, LPSTR lpszString );
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
int showCoreVersionInfo( void )
hgs
parents:
diff changeset
    34
{
hgs
parents:
diff changeset
    35
	LOG_FUNC_ENTRY( "version.cpp::showCoreVersionInfo" );
hgs
parents:
diff changeset
    36
	// Try find header from environment where to locate version info.
hgs
parents:
diff changeset
    37
	string sHeaderFile = findAnalyzeToolHeader();
hgs
parents:
diff changeset
    38
	if ( sHeaderFile.empty() )
hgs
parents:
diff changeset
    39
		return 0;
hgs
parents:
diff changeset
    40
	string sVersion("");
hgs
parents:
diff changeset
    41
	if ( readCoreVersionInfo( sHeaderFile, sVersion ) )
hgs
parents:
diff changeset
    42
	{
hgs
parents:
diff changeset
    43
		cout << "AnalyzeTool SDK binaries version: " 
hgs
parents:
diff changeset
    44
			<< sVersion
hgs
parents:
diff changeset
    45
			<< endl;
hgs
parents:
diff changeset
    46
	}
hgs
parents:
diff changeset
    47
	return 0;
hgs
parents:
diff changeset
    48
}
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
/**
hgs
parents:
diff changeset
    52
* Find analyzetool.h header file
hgs
parents:
diff changeset
    53
* @return string containing full path to file or empty string if not found.
hgs
parents:
diff changeset
    54
*/
hgs
parents:
diff changeset
    55
string findAnalyzeToolHeader( void )
hgs
parents:
diff changeset
    56
{
hgs
parents:
diff changeset
    57
	LOG_FUNC_ENTRY( "version.cpp::findAnalyzeToolHeader" );
hgs
parents:
diff changeset
    58
	string sEpocRoot;
hgs
parents:
diff changeset
    59
	if ( ! CATBase::GetEpocRoot( sEpocRoot ) )
hgs
parents:
diff changeset
    60
		return string("");
hgs
parents:
diff changeset
    61
	int iC = sizeof( AT_CORE_INCLUDE_FILE_WITH_VERSION_NUMBER ) / sizeof ( string );
hgs
parents:
diff changeset
    62
	for( int i = 0 ; i < iC ; i++ )
hgs
parents:
diff changeset
    63
	{
hgs
parents:
diff changeset
    64
		string sCheck( sEpocRoot );
hgs
parents:
diff changeset
    65
		sCheck.append( AT_CORE_INCLUDE_FILE_WITH_VERSION_NUMBER[i] );
hgs
parents:
diff changeset
    66
		if ( CATBase::FileExists( sCheck.c_str() ) )
hgs
parents:
diff changeset
    67
			return sCheck;
hgs
parents:
diff changeset
    68
	}
hgs
parents:
diff changeset
    69
	return string("");
hgs
parents:
diff changeset
    70
}
hgs
parents:
diff changeset
    71
/**
hgs
parents:
diff changeset
    72
* Read core version string.
hgs
parents:
diff changeset
    73
* @param sVersion string will contain version info if funtion returns true.
hgs
parents:
diff changeset
    74
* @return true if successful.
hgs
parents:
diff changeset
    75
*/
hgs
parents:
diff changeset
    76
bool readCoreVersionInfo( const string& sFile, string& sVersion )
hgs
parents:
diff changeset
    77
{
hgs
parents:
diff changeset
    78
	LOG_FUNC_ENTRY( "version.cpp::readCoreVersionInfo" );
hgs
parents:
diff changeset
    79
	try {
hgs
parents:
diff changeset
    80
		ifstream in;
hgs
parents:
diff changeset
    81
		in.open( sFile.c_str() );
hgs
parents:
diff changeset
    82
		if ( ! in.good() )
hgs
parents:
diff changeset
    83
			return false;
hgs
parents:
diff changeset
    84
		char cBuff[MAX_LINE_LENGTH];
hgs
parents:
diff changeset
    85
		while ( in.good() )
hgs
parents:
diff changeset
    86
		{
hgs
parents:
diff changeset
    87
			in.getline( cBuff, MAX_LINE_LENGTH );
hgs
parents:
diff changeset
    88
			string s( cBuff );
hgs
parents:
diff changeset
    89
			if ( s.find( AT_CORE_VERSION_NUMBER_TAG ) != string::npos )
hgs
parents:
diff changeset
    90
			{
hgs
parents:
diff changeset
    91
				// Find spot after first space (ignore first 3 chars).
hgs
parents:
diff changeset
    92
				size_t t =  s.find_first_of( ' ', 3 )+1;
hgs
parents:
diff changeset
    93
				sVersion = s.substr( t, s.size()-t );
hgs
parents:
diff changeset
    94
				return true;
hgs
parents:
diff changeset
    95
			}
hgs
parents:
diff changeset
    96
		}
hgs
parents:
diff changeset
    97
	}
hgs
parents:
diff changeset
    98
	catch(...)
hgs
parents:
diff changeset
    99
	{
hgs
parents:
diff changeset
   100
		LOG_STRING(AT_MSG << "Exception reading core version info.");
hgs
parents:
diff changeset
   101
	}
hgs
parents:
diff changeset
   102
	return false;
hgs
parents:
diff changeset
   103
}
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
/**
hgs
parents:
diff changeset
   106
* Print version information of atool.exe binary.
hgs
parents:
diff changeset
   107
*/
hgs
parents:
diff changeset
   108
int showVersionInfo( void )
hgs
parents:
diff changeset
   109
{
hgs
parents:
diff changeset
   110
	LOG_FUNC_ENTRY( "version.cpp::showVersionInfo" );
hgs
parents:
diff changeset
   111
	string sTemp( "Version: " );
hgs
parents:
diff changeset
   112
	sTemp.append( ATOOL_VERSION );
hgs
parents:
diff changeset
   113
	sTemp.append( "\n" );
hgs
parents:
diff changeset
   114
	//Print atool version
hgs
parents:
diff changeset
   115
	printf( sTemp.c_str() );
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
	//atool.exe:s path + filename
hgs
parents:
diff changeset
   118
	char buffer[MAX_PATH];
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
	GetModuleFileName( NULL, buffer, MAX_PATH );
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
	printf( "Path: %s\n", buffer );
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
	WIN32_FIND_DATA FindFileData;
hgs
parents:
diff changeset
   125
	HANDLE hFind;
hgs
parents:
diff changeset
   126
	//Get file handle
hgs
parents:
diff changeset
   127
	hFind = FindFirstFile( buffer, &FindFileData );
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
	if( hFind == INVALID_HANDLE_VALUE )
hgs
parents:
diff changeset
   130
	{
hgs
parents:
diff changeset
   131
		printf( "Can not find file:%s", buffer );
hgs
parents:
diff changeset
   132
		return 0;
hgs
parents:
diff changeset
   133
	}
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
	convertWriteTimeToLocalTime( FindFileData.ftLastWriteTime , buffer );
hgs
parents:
diff changeset
   136
	printf( "Modified: %s\n", buffer );
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
	// Show core version information.
hgs
parents:
diff changeset
   139
	showCoreVersionInfo();
hgs
parents:
diff changeset
   140
	return 0;
hgs
parents:
diff changeset
   141
}
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
// Convert the last-write time to local time.
hgs
parents:
diff changeset
   144
void convertWriteTimeToLocalTime( FILETIME ftWrite, LPSTR lpszString )
hgs
parents:
diff changeset
   145
{
hgs
parents:
diff changeset
   146
	LOG_FUNC_ENTRY( "version.cpp::convertWriteTimeToLocalTime" );
hgs
parents:
diff changeset
   147
	SYSTEMTIME stUTC, stLocal;
hgs
parents:
diff changeset
   148
    // Convert the last-write time to local time.
hgs
parents:
diff changeset
   149
    FileTimeToSystemTime(&ftWrite, &stUTC);
hgs
parents:
diff changeset
   150
    SystemTimeToTzSpecificLocalTime(NULL, &stUTC, &stLocal);
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
    // Build a string showing the date and time.
hgs
parents:
diff changeset
   153
    wsprintf(lpszString, "%02d/%02d/%d %02d:%02d:%02d",
hgs
parents:
diff changeset
   154
        stLocal.wDay, stLocal.wMonth, stLocal.wYear,
hgs
parents:
diff changeset
   155
        stLocal.wHour, stLocal.wMinute, stLocal.wSecond);
hgs
parents:
diff changeset
   156
}
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
/**
hgs
parents:
diff changeset
   159
* Print version information of dbghelp.dll.
hgs
parents:
diff changeset
   160
*/
hgs
parents:
diff changeset
   161
int showDbgHelpVersionInfo( bool showVersion )
hgs
parents:
diff changeset
   162
{
hgs
parents:
diff changeset
   163
	LOG_FUNC_ENTRY( "version.cpp::showDbgHelpVersionInfo" );
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
	WORD majorVersion;
hgs
parents:
diff changeset
   166
	WORD minorVersion;
hgs
parents:
diff changeset
   167
	WORD buildNumber;
hgs
parents:
diff changeset
   168
	WORD revisionNumber;
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
	if(getDllVersion( _T(DBGHELP_DLL_NAME), &majorVersion, &minorVersion, &buildNumber, &revisionNumber))
hgs
parents:
diff changeset
   171
	{
hgs
parents:
diff changeset
   172
		//Check if current dll version is lower than latest version
hgs
parents:
diff changeset
   173
		if((majorVersion < DBGHELP_VERSION_MAJ) ||
hgs
parents:
diff changeset
   174
			(majorVersion == DBGHELP_VERSION_MAJ && minorVersion < DBGHELP_VERSION_MIN) ||
hgs
parents:
diff changeset
   175
			(majorVersion == DBGHELP_VERSION_MAJ && minorVersion == DBGHELP_VERSION_MIN && buildNumber < DBGHELP_VERSION_BUILD) ||
hgs
parents:
diff changeset
   176
			(majorVersion == DBGHELP_VERSION_MAJ && minorVersion == DBGHELP_VERSION_MIN && buildNumber == DBGHELP_VERSION_BUILD && revisionNumber < DBGHELP_VERSION_REVIS))
hgs
parents:
diff changeset
   177
		{
hgs
parents:
diff changeset
   178
			cout << "WARNING: Version of your dbghelp.dll is "
hgs
parents:
diff changeset
   179
					<< majorVersion << "."
hgs
parents:
diff changeset
   180
					<< minorVersion << "."
hgs
parents:
diff changeset
   181
					<< buildNumber << "."
hgs
parents:
diff changeset
   182
					<< revisionNumber << ".\n";
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
			cout << "Source code pinpointing for winscw may not work properly with this version."
hgs
parents:
diff changeset
   185
				<< endl
hgs
parents:
diff changeset
   186
				<< "Please, update it to at least version "
hgs
parents:
diff changeset
   187
				<< DBGHELP_VERSION_MAJ << "." 
hgs
parents:
diff changeset
   188
				<< DBGHELP_VERSION_MIN << "." 
hgs
parents:
diff changeset
   189
				<< DBGHELP_VERSION_BUILD << "." 
hgs
parents:
diff changeset
   190
				<< DBGHELP_VERSION_REVIS << ".\n"
hgs
parents:
diff changeset
   191
				<< "dbghelp.dll file is included in Debugging Tools from Microsoft. "
hgs
parents:
diff changeset
   192
				<< "You can download and install it from\n"
hgs
parents:
diff changeset
   193
				<< "http://www.microsoft.com/whdc/devtools/debugging/\n";
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
			return 1;
hgs
parents:
diff changeset
   196
		}
hgs
parents:
diff changeset
   197
		else
hgs
parents:
diff changeset
   198
		{
hgs
parents:
diff changeset
   199
			if( showVersion )
hgs
parents:
diff changeset
   200
			{
hgs
parents:
diff changeset
   201
				cout << "Version of your dbghelp.dll is "
hgs
parents:
diff changeset
   202
					<< majorVersion << "."
hgs
parents:
diff changeset
   203
				    << minorVersion << "."
hgs
parents:
diff changeset
   204
				    << buildNumber << "."
hgs
parents:
diff changeset
   205
				    << revisionNumber << "."
hgs
parents:
diff changeset
   206
				    << endl;
hgs
parents:
diff changeset
   207
				cout << "No need for update.\n";
hgs
parents:
diff changeset
   208
			}
hgs
parents:
diff changeset
   209
		}
hgs
parents:
diff changeset
   210
	}
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
	return 0;
hgs
parents:
diff changeset
   213
}
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
/**
hgs
parents:
diff changeset
   216
* Get dll version.
hgs
parents:
diff changeset
   217
* @param libName library name.
hgs
parents:
diff changeset
   218
* @param majorVersion will contain major version if funtion returns true.
hgs
parents:
diff changeset
   219
* @param minorVersion will contain minor version if funtion returns true.
hgs
parents:
diff changeset
   220
* @param buildNumber will contain build number if funtion returns true.
hgs
parents:
diff changeset
   221
* @param revisionNumber will contain revision number if funtion returns true.
hgs
parents:
diff changeset
   222
* @return true if successful.
hgs
parents:
diff changeset
   223
*/
hgs
parents:
diff changeset
   224
int getDllVersion( LPCTSTR  libName, WORD *majorVersion, WORD *minorVersion, WORD *buildNumber, WORD *revisionNumber ) 
hgs
parents:
diff changeset
   225
{
hgs
parents:
diff changeset
   226
	LOG_FUNC_ENTRY( "version.cpp::getDllVersion" );
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
	DWORD dwHandle, dwLen;
hgs
parents:
diff changeset
   229
	UINT BufLen;
hgs
parents:
diff changeset
   230
	LPTSTR lpData;
hgs
parents:
diff changeset
   231
	VS_FIXEDFILEINFO *pFileInfo;
hgs
parents:
diff changeset
   232
	dwLen = GetFileVersionInfoSize( libName, &dwHandle );
hgs
parents:
diff changeset
   233
	if (!dwLen)
hgs
parents:
diff changeset
   234
		return 0;
hgs
parents:
diff changeset
   235
	
hgs
parents:
diff changeset
   236
	lpData = (LPTSTR) malloc (dwLen);
hgs
parents:
diff changeset
   237
	if (!lpData)
hgs
parents:
diff changeset
   238
		return 0;
hgs
parents:
diff changeset
   239
	
hgs
parents:
diff changeset
   240
	if( !GetFileVersionInfo( libName, dwHandle, dwLen, lpData ) )
hgs
parents:
diff changeset
   241
	{
hgs
parents:
diff changeset
   242
		free (lpData);
hgs
parents:
diff changeset
   243
		return 0;
hgs
parents:
diff changeset
   244
	}
hgs
parents:
diff changeset
   245
	
hgs
parents:
diff changeset
   246
	if( VerQueryValue( lpData, _T("\\"), (LPVOID *) &pFileInfo, (PUINT)&BufLen ) )
hgs
parents:
diff changeset
   247
	{
hgs
parents:
diff changeset
   248
		*majorVersion = HIWORD(pFileInfo->dwFileVersionMS);
hgs
parents:
diff changeset
   249
		*minorVersion = LOWORD(pFileInfo->dwFileVersionMS);
hgs
parents:
diff changeset
   250
		*buildNumber = HIWORD(pFileInfo->dwFileVersionLS);
hgs
parents:
diff changeset
   251
		*revisionNumber = LOWORD(pFileInfo->dwFileVersionLS);
hgs
parents:
diff changeset
   252
		return 1;
hgs
parents:
diff changeset
   253
	 }
hgs
parents:
diff changeset
   254
	free (lpData);
hgs
parents:
diff changeset
   255
	return 0;
hgs
parents:
diff changeset
   256
}
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
//EOF