Windows2003-3790/admin/published/cmdline/cmdline.w
2020-09-30 16:53:55 +02:00

1102 lines
50 KiB
OpenEdge ABL

// ****************************************************************************
//
// Copyright (c) 2000 Microsoft Corporation
//
// Module Name:
//
// Cmdline.h
//
// Abstract:
//
// This modules contains the common functionality file headers and type
// definitions
//
// Author:
//
// Sunil G.V.N. Murali (murali.sunil@wipro.com) 1-Sep-2000
//
// Revision History:
//
// Sunil G.V.N. Murali (murali.sunil@wipro.com) 1-Sep-2000 : Created It.
//
// ****************************************************************************
#ifndef __CMDLINE_H
#define __CMDLINE_H
#ifndef CMDLINE_VERSION
#define CMDLINE_VERSION 100
#endif
#ifndef UNICODE
#error this library can be compiled only in UNICODE environment
#endif
#ifdef __cplusplus
extern "C" {
#endif
// constants / defines
#define MAX_RES_STRING 254
#define MAX_STRING_LENGTH 254
// stubs for 'displaying'
#define DISPLAY_MESSAGE( file, message ) ShowMessage( file, message )
#if CMDLINE_VERSION == 100
// ****************************************************************************
// all the below stuff in deprecated in cmdline library version
// greater that 1.0
// ****************************************************************************
//
// custom macros ( for trapping memory leaks )
//
#ifdef _DEBUG
#define __malloc( size ) \
_malloc_dbg( size, _NORMAL_BLOCK, __FILE__, __LINE__ )
#define __calloc( count, size ) \
_calloc_dbg( count, size, _NORMAL_BLOCK, __FILE__, __LINE__ )
#define __free( block ) \
if ( (block) != NULL ) \
{ \
_free_dbg( (block), _NORMAL_BLOCK ); \
(block) = NULL; \
} \
1
#define __realloc( block, size ) \
(((block) != NULL) ? \
_realloc_dbg( (block), size, \
_NORMAL_BLOCK, __FILE__, __LINE__ ) : \
__malloc( size ))
#else // #ifdef _DEBUG
#define __malloc( size ) malloc( size )
#define __calloc( count, size ) calloc( count, size )
#define __free( block ) \
if ( (block) != NULL ) \
{ \
free( (block) ); \
(block) = NULL; \
} \
1
#define __realloc( block, size ) \
(((block) != NULL) ? realloc( block, size ) : __malloc( size ))
#endif // #ifdef _DEBUG
//
// custom macros
//
#define CHECK_NULL( statement, value ) \
if ( ( statement ) == NULL ) \
{ \
return value; \
} \
1
#define SHOW_RESULT_MESSAGE( server, tag, message ) \
if ( IsLocalSystem( server ) == TRUE ) \
{ \
DISPLAY_MESSAGE2( stderr, szBuffer, \
_T( "%s %s" ), tag, message ); \
} \
else \
{ \
DISPLAY_MESSAGE3( stderr, szBuffer, \
_T( "%s %s: %s" ), tag, server, message ); \
} \
1
//
// string formatting stubs
#define FORMAT_STRING( buffer, format, value ) \
swprintf( buffer, format, value )
#define FORMAT_STRING2( buffer, format, value1, value2 ) \
swprintf( buffer, format, value1, value2 )
#define FORMAT_STRING3( buffer, format, value1, value2, value3 ) \
swprintf( buffer, format, value1, value2, value3 )
#define FORMAT_STRING_EX( buffer, format, value, length, alignflag ) \
swprintf( buffer, format, value ); \
AdjustStringLength( buffer, length, alignflag )
#define FORMAT_STRING_EX2( buffer, format, value1, value2, length, alignflag ) \
swprintf( buffer, format, value1, value2 ); \
AdjustStringLength( buffer, length, alignflag )
#define FORMAT_STRING_EX3( buffer, format, value1, value2, value3, length, alignflag ) \
swprintf( buffer, format, value1, value2, value3 ); \
AdjustStringLength( buffer, length, alignflag )
//
// stubs for 'displaying'
#define DISPLAY_MESSAGE( file, message ) \
ShowMessage( file, message )
#define DISPLAY_MESSAGE1( file, buffer, format, value1 ) \
FORMAT_STRING( buffer, format, value1 ); \
ShowMessage( file, buffer )
#define DISPLAY_MESSAGE2( file, buffer, format, value1, value2 ) \
FORMAT_STRING2( buffer, format, value1, value2 ); \
ShowMessage( file, buffer )
#define DISPLAY_MESSAGE3( file, buffer, format, value1, value2, value3 ) \
FORMAT_STRING3( buffer, format, value1, value2, value3 ); \
ShowMessage( file, buffer )
//
// display messages from resource file's string table ( stubs )
#define DISPLAY_RES_MESSAGE( file, id ) \
ShowResMessage( file, id )
#define DISPLAY_RES_MESSAGE1( file, buffer, id, value1 ) \
FORMAT_STRING( buffer, GetResString( id ), value1 ); \
ShowMessage( file, buffer )
#define DISPLAY_RES_MESSAGE2( file, buffer, id, value1, value2 ) \
FORMAT_STRING2( buffer, GetResString( id ), value1, value2 ); \
ShowMessage( file, buffer )
#define DISPLAY_RES_MESSAGE3( file, buffer, id, value1, value2, value3 ) \
FORMAT_STRING3( buffer, GetResString( id ), value1, value2, value3 ); \
ShowMessage( file, buffer )
#define MAX_USERNAME_LENGTH 64
#define MAX_PASSWORD_LENGTH 64
#define FULL_SUCCESS 0
#define PARTIALLY_SUCCESS 128
#define COMPLETELY_FAILED 255
//
// type definitions
//
typedef TCHAR __STRING_32[ 32 ];
typedef TCHAR __STRING_64[ 64 ];
typedef TCHAR __STRING_128[ 128 ];
typedef TCHAR __STRING_256[ 256 ];
typedef TCHAR __STRING_512[ 512 ];
typedef TCHAR __STRING_1024[ 1024 ];
typedef TCHAR __STRING_2048[ 2048 ];
typedef TCHAR __STRING_4096[ 4096 ];
typedef TCHAR __RESOURCE_STRING [ MAX_RES_STRING + 1 ];
typedef TCHAR __MAX_SIZE_STRING[ MAX_STRING_LENGTH + 1 ];
// string manipulation macros
#define STRING_COPY_STATIC( destination, source ) \
StringCopy( destination, source, SIZE_OF_ARRAY( destination ) )
#define STRING_COPY_DYNAMIC( destination, source ) \
StringCopyEx( destination, source )
#define STRING_CONCAT_STATIC( destination, source ) \
StringConcat( destination, source, SIZE_OF_ARRAY( destination ) )
#define STRING_CONCAT_DYNAMIC( destination, source ) \
StringConcatEx( destination, source )
#define STRING_COPY( destination, source ) \
if ( destination != NULL && _msize( destination ) != -1 ) \
{ \
STRING_COPY_DYNAMIC( destination, source ); \
} \
else \
{ \
STRING_COPY_STATIC( destination, source ); \
} \
1
#define STRING_CONCAT( destination, source ) \
if ( destination != NULL && _msize( destination ) != -1 ) \
{ \
STRING_CONCAT_DYNAMIC( destination, source ); \
} \
else \
{ \
STRING_CONCAT_STATIC( destination, source ); \
} \
1
//
// function re-defs
//
#ifdef UNICODE
#define GetCompatibleStringFromMultiByte GetAsUnicodeStringEx
#define GetCompatibleStringFromUnicode GetAsUnicodeString
#else
#define GetCompatibleStringFromMultiByte GetAsMultiByteString
#define GetCompatibleStringFromUnicode GetAsMultiByteStringEx
#endif // UNICODE
/////////
// conversion functions
// old legacy functions -- these are made obsolete
LPSTR GetAsMultiByteString( LPCWSTR pszSource,
LPSTR pszDestination, DWORD dwLength );
LPWSTR GetAsUnicodeStringEx( LPCSTR pszSource,
LPWSTR pwszDestination, DWORD dwLength );
/////////
// this function is mapped to the StringCopyW
// LPWSTR GetAsUnicodeString( LPCWSTR pszSource,
// LPWSTR pwszDestination,
// DWORD dwLength );
#define GetAsUnicodeString( source, \
destination, \
length ) StringCopyW( destination, \
source, \
length )
/////////
// this function is mapped to its another function which is of similar type
// LPSTR GetAsMultiByteStringEx( LPCWSTR pwszSource,
// LPSTR pszDestination, DWORD dwLength );
#define GetAsMultiByteStringEx GetAsMultiByteString
// ****************************************************************************
// all the above stuff is deprecated in cmdline library version
// greater that 1.0
// ****************************************************************************
#endif // CMDLINE_VERSION == 100
///////////////////////////////////////////////////////////////////////////////
// //
// COMMON FUNCTIONALITY //
// //
///////////////////////////////////////////////////////////////////////////////
// wrappers for quote meta
#define _X( text ) text
#define _X1( text ) text
#define _X2( text ) text
#define _X3( text ) text
//
// macros
//
#define TAG_ERROR GetResString( IDS_TAG_ERROR )
#define TAG_WARNING GetResString( IDS_TAG_WARNING )
#define TAG_SUCCESS GetResString( IDS_TAG_SUCCESS )
#define TAG_INFORMATION GetResString( IDS_TAG_INFORMATION )
#define SIZE_OF_ARRAY( array ) ( sizeof( array ) / sizeof( array[ 0 ] ) )
//
// constants / defines / enumerations
//
#define _DEFAULT_CODEPAGE CP_OEMCP
#define BACK_SPACE 0x08
#define BLANK_CHAR 0x00
#define CARRIAGE_RETURN 0x0D
#define ASTERIX _T( "*" )
#define BEEP_SOUND _T( "\a" )
#define TRIM_LEFT 0x00000001
#define TRIM_RIGHT 0x00000002
#define TRIM_ALL 0x00000003
extern const WCHAR cwchNullChar;
extern const WCHAR cwszNullString[ 2 ];
#if CMDLINE_VERSION == 100
#define NULL_CHAR L'\0'
#define NULL_STRING L"\0"
#endif
#define V_NOT_AVAILABLE GetResString( IDS_V_NOT_AVAILABLE )
#define ERROR_OS_INCOMPATIBLE GetResString( IDS_ERROR_OS_INCOMPATIBLE )
#define ERROR_REMOTE_INCOMPATIBLE GetResString( IDS_ERROR_REMOTE_INCOMPATIBLE )
// macros for copy or concatenation ansi/unicode strings
#ifdef UNICODE
#define StringCopy StringCopyW
#define StringCopyEx StringCopyExW
#define StringConcat StringConcatW
#define StringConcatEx StringConcatExW
#define StringLength StringLengthW
#define StringCompare StringCompareW
#define StringCompareEx StringCompareExW
#else
#define StringCopy StringCopyA
#define StringCopyEx StringCopyExA
#define StringConcat StringConcatA
#define StringConcatEx StringConcatExA
#define StringLength StringLengthA
#define StringCompare StringCompareA
#define StringCompareEx StringCompareExA
#endif
//
// flags -- specific to ShowLastErrorEx
#define SLE_TYPE_ERROR 0x00000001
#define SLE_TYPE_INFO 0x00000002
#define SLE_TYPE_WARNING 0x00000004
#define SLE_TYPE_SUCCESS 0x00000008
#define SLE_SYSTEM 0x00010000
#define SLE_INTERNAL 0x00020000
#define SLE_MASK 0x000F0000
//
// pattern matching flags
#define PATTERN_LOCALE_USENGLISH 0x00000001
#define PATTERN_NOPARSING 0x00000002
#define PATTERN_COMPARE_IGNORECASE 0x00000100
#define PATTERN_COMPARE_IGNOREKANATYPE 0x00000200
#define PATTERN_COMPARE_IGNORENONSPACE 0x00000400
#define PATTERN_COMPARE_IGNORESYMBOLS 0x00000800
#define PATTERN_COMPARE_IGNOREWIDTH 0x00001000
#define PATTERN_COMPARE_STRINGSORT 0x00002000
//
// function prototypes
//
BOOL InitGlobals();
LPCWSTR GetReason();
BOOL SetReason( LPCWSTR pwszReason );
BOOL SetReason2( DWORD dwCount, LPCWSTR pwszFormat, ... );
BOOL SaveLastError();
DWORD WNetSaveLastError();
BOOL ShowLastError( FILE* fp );
BOOL ShowLastErrorEx( FILE* fp, DWORD dwFlags );
BOOL ReleaseGlobals();
BOOL IsWin2KOrLater();
BOOL IsCompatibleOperatingSystem( DWORD dwVersion );
BOOL SetOsVersion( DWORD dwMajor, DWORD dwMinor, WORD wServicePackMajor );
LPCWSTR GetResString( UINT uID );
LPCWSTR GetResString2( UINT uID, DWORD dwIndexNumber );
double AsFloat( LPCWSTR pwszValue );
BOOL IsFloatingPoint( LPCWSTR pwszValue );
LONG AsLong( LPCWSTR pwszValue, DWORD dwBase );
BOOL IsNumeric( LPCWSTR pwszValue, DWORD dwBase, BOOL bSigned );
LPCWSTR FindChar( LPCWSTR pwszString, WCHAR wch, DWORD dwFrom );
LONG FindChar2( LPCWSTR pwszString, WCHAR wch, BOOL bIgnoreCase, DWORD dwFrom );
BOOL InString( LPCWSTR pwszString, LPCWSTR pwszList, BOOL bIgnoreCase );
LPCWSTR FindOneOf( LPCWSTR pwszText, LPCWSTR pwszTextToFind, DWORD dwFrom );
LONG FindOneOf2( LPCWSTR pwszText, LPCWSTR pwszTextToFind, BOOL bIgnoreCase, DWORD dwFrom );
LPCWSTR FindString( LPCWSTR pwszText, LPCWSTR pwszTextToFind, DWORD dwFrom );
LONG FindString2( LPCWSTR pwszText, LPCWSTR pwszTextToFind, BOOL bIgnoreCase, DWORD dwFrom );
LONG StringLengthInBytes( LPCWSTR pwszText );
LPCWSTR TrimString( LPWSTR pwszString, DWORD dwFlags );
LPCWSTR TrimString2( LPWSTR pwszString, LPCWSTR pwszTrimChars, DWORD dwFlags );
LPCWSTR QuoteMeta( LPCWSTR pwszText, DWORD dwQuoteIndex );
LPCWSTR AdjustStringLength( LPWSTR pwszValue, DWORD dwLength, BOOL bPadLeft );
LPCWSTR Replicate( LPWSTR pwszBuffer,
LPCWSTR pwszText, DWORD dwCount, DWORD dwLength );
BOOL IsConsoleFile( FILE* fp );
LCID GetSupportedUserLocale( BOOL* pbLocaleChanged );
BOOL StringCopyExA( LPSTR pszDest, LPCSTR pszSource );
BOOL StringConcatExA( LPSTR pszDest, LPCSTR pszSource );
BOOL StringCopyExW( LPWSTR pwszDest, LPCWSTR pwszSource );
BOOL StringConcatExW( LPWSTR pwszDest, LPCWSTR pwszSource );
BOOL StringCopyA( LPSTR pszDest, LPCSTR pszSource, LONG lSize );
BOOL StringConcatA( LPSTR pszDest, LPCSTR pszSource, LONG lSize );
BOOL StringCopyW( LPWSTR pwszDest, LPCWSTR pwszSource, LONG lSize );
BOOL StringConcatW( LPWSTR pwszDest, LPCWSTR pwszSource, LONG lSize );
DWORD StringLengthA( LPCSTR pszSource, DWORD dwReserved );
DWORD StringLengthW( LPCWSTR pwszSource, DWORD dwReserved );
LONG StringCompareW( LPCWSTR pwszString1,
LPCWSTR pwszString2, BOOL bIgnoreCase, DWORD dwCount );
LONG StringCompareA( LPCSTR pwszString1,
LPCSTR pwszString2, BOOL bIgnoreCase, DWORD dwCount );
LONG StringCompareExW( LPCWSTR pwszString1,
LPCWSTR pwszString2, BOOL bIgnoreCase, DWORD dwCount );
LONG StringCompareExA( LPCSTR pwszString1,
LPCSTR pwszString2, BOOL bIgnoreCase, DWORD dwCount );
BOOL ShowResMessage( FILE* fp, UINT uID );
BOOL ShowMessage( FILE* fp, LPCWSTR pwszMessage );
BOOL ShowMessageEx( FILE* fp, DWORD dwCount, BOOL bStyle, LPCWSTR pwszFormat, ... );
BOOL GetAsUnicodeString2( LPCSTR pszSource, LPWSTR pwszDestination, DWORD* pdwLength );
BOOL GetAsMultiByteString2( LPCWSTR pwszSource, LPSTR pszDestination, DWORD* pdwLength );
BOOL GetPassword( LPWSTR pwszPassword, DWORD dwMaxPasswordSize );
BOOL MatchPattern( LPWSTR pwszPattern, LPWSTR pwszText );
LPCWSTR ParsePattern( LPCWSTR pwszPattern );
BOOL MatchPatternEx( LPCWSTR pwszText, LPCWSTR pwszPattern, DWORD dwFlags );
BOOL FreeMemory( LPVOID* ppv );
BOOL CheckMemory( LPVOID pv );
LPVOID AllocateMemory( DWORD dwBytes );
BOOL ReallocateMemory( LPVOID* ppv, DWORD dwBytesNew );
LONG GetBufferSize( LPVOID pv );
///////////////////////////////////////////////////////////////////////////////
// //
// REMOTE CONNECTIVITY //
// //
///////////////////////////////////////////////////////////////////////////////
//
// error codes
//
#define E_LOCAL_CREDENTIALS 0xA0010001 // 1010 0000 0000 0001 0000 0000 0000 0001
#define I_NO_CLOSE_CONNECTION 0x50010001 // 0101 0000 0000 0001 0000 0000 0000 0001
//
// structs
//
typedef struct tagConnectionInfo
{
DWORD dwFlags; // flags
LPCTSTR pszServer; // server name
LPTSTR pszUserName; // user name
DWORD dwUserLength; // max. no. of characters allowed for user name
LPTSTR pszPassword; // password
DWORD dwPasswordLength; // max. no. of characters allowed for password
LPCTSTR pszShare; // tells the custom share name
LPVOID lpReserved1; // reserved for future use
LPVOID lpReserved2; // reserved for future use
LPVOID lpReserved3; // reserved for future use
} TCONNECTIONINFO, *PTCONNECTIONINFO;
//
// connection info flags
//
// general flags
#define CI_ACCEPT_PASSWORD 0x00000001 // 0000 0001
// share (if nothing specified, default will be assumed as IPC$ )
#define CI_SHARE_IPC 0x00000010 // 0000 0000 0001 XXXX XXXX
#define CI_SHARE_ADMIN 0x00000020 // 0000 0000 0010 XXXX XXXX
#define CI_SHARE_CUSTOM 0x00000040 // 0000 0001 0000 XXXX XXXX
// extra flag used while closing connection
#define CI_CLOSE_BY_FORCE 0x10000000
//
// function prototypes
//
BOOL IsUserAdmin();
BOOL IsUNCFormat( LPCWSTR pwszServer );
BOOL IsLocalSystem( LPCWSTR pwszServer );
BOOL IsValidServer( LPCWSTR pwszServer );
BOOL IsValidIPAddress( LPCWSTR pwszAddress );
BOOL GetHostByIPAddr( LPCWSTR pwszServer,
LPWSTR pwszHostName,
DWORD* pdwHostNameLength, BOOL bNeedFQDN );
DWORD GetTargetVersion( LPCWSTR pwszServer );
DWORD ConnectServer( LPCWSTR pwszServer, LPCWSTR pwszUser, LPCWSTR pwszPassword );
DWORD ConnectServer2( LPCWSTR pwszServer, LPCWSTR pwszUser,
LPCWSTR pwszPassword, LPCWSTR pwszShare );
DWORD CloseConnection( LPCWSTR pwszServer );
DWORD CloseConnection2( LPCWSTR pwszServer, LPCWSTR pwszShare, DWORD dwFlags );
BOOL EstablishConnectionEx( PTCONNECTIONINFO pci );
BOOL EstablishConnection( LPCWSTR pwszServer,
LPWSTR pwszUserName, DWORD dwUserLength,
LPWSTR pwszPassword, DWORD dwPasswordLength, BOOL bNeedPassword );
///////////////////////////////////////////////////////////////////////////////
// //
// MULTI-DIMENSIONAL MULTI-TYPE DYNAMIC ARRAYS //
// //
///////////////////////////////////////////////////////////////////////////////
//
// constants / defines / enumerations
//
// item types supported by dynamic array
#define DA_TYPE_NONE 0x00000000
#define DA_TYPE_GENERAL 0x00010000
#define DA_TYPE_STRING 0x00020000
#define DA_TYPE_LONG 0x00030000
#define DA_TYPE_DWORD 0x00040000
#define DA_TYPE_BOOL 0x00050000
#define DA_TYPE_FLOAT 0x00060000
#define DA_TYPE_DOUBLE 0x00070000
#define DA_TYPE_ARRAY 0x00080000
#define DA_TYPE_HANDLE 0x00090000
#define DA_TYPE_SYSTEMTIME 0x000A0000
#define DA_TYPE_FILETIME 0x000B0000
//
// type definitions
//
typedef VOID* TARRAY;
typedef TARRAY* PTARRAY;
//
// public function prototypes
//
//
// array pointer validation function(s)
BOOL IsValidArray( TARRAY pArray );
//
// dynamic array creation / destraction functions
TARRAY CreateDynamicArray();
VOID DestroyDynamicArray( PTARRAY pArray );
//
// general helper function(s)
DWORD DynArrayGetCount( TARRAY pArray );
DWORD DynArrayGetCount2( TARRAY pArray, DWORD dwRow );
DWORD DynArrayGetItemType( TARRAY pArray, DWORD dwIndex );
DWORD DynArrayGetItemType2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
//
// adding columns
LONG DynArrayAddColumns( TARRAY pArray, DWORD dwColumns );
LONG DynArrayInsertColumns( TARRAY pArray, DWORD dwIndex, DWORD dwColumns );
//
// array append function(s) ( for one-dimensional array )
LONG DynArrayAppend( TARRAY pArray, LPVOID pValue );
LONG DynArrayAppendLong( TARRAY pArray, LONG lValue );
LONG DynArrayAppendBOOL( TARRAY pArray, BOOL bValue );
LONG DynArrayAppendDWORD( TARRAY pArray, DWORD dwValue );
LONG DynArrayAppendFloat( TARRAY pArray, float dwValue );
LONG DynArrayAppendDouble( TARRAY pArray, double dwValue );
LONG DynArrayAppendString( TARRAY pArray, LPCTSTR szValue, DWORD dwLength );
LONG DynArrayAppendHandle( TARRAY pArray, HANDLE hValue );
LONG DynArrayAppendSystemTime( TARRAY pArray, SYSTEMTIME stValue );
LONG DynArrayAppendFileTime( TARRAY pArray, FILETIME ftValue );
// helper to append 2-dimensional array
LONG DynArrayAppendRow( TARRAY pArray, DWORD dwColumns );
// ( for two-dimensional array )
LONG DynArrayAppend2( TARRAY pArray, DWORD dwRow, LPVOID pValue );
LONG DynArrayAppendLong2( TARRAY pArray, DWORD dwRow, LONG lValue );
LONG DynArrayAppendBOOL2( TARRAY pArray, DWORD dwRow, BOOL bValue );
LONG DynArrayAppendDWORD2( TARRAY pArray, DWORD dwRow, DWORD dwValue );
LONG DynArrayAppendFloat2( TARRAY pArray, DWORD dwRow, float dwValue );
LONG DynArrayAppendDouble2( TARRAY pArray, DWORD dwRow, double dwValue );
LONG DynArrayAppendString2( TARRAY pArray, DWORD dwRow, LPCTSTR szValue, DWORD dwLength );
LONG DynArrayAppendHandle2( TARRAY pArray, DWORD dwRow, HANDLE hValue );
LONG DynArrayAppendSystemTime2( TARRAY pArray, DWORD dwRow, SYSTEMTIME stValue );
LONG DynArrayAppendFileTime2( TARRAY pArray, DWORD dwRow, FILETIME ftValue );
//
// array insert function(s) ( for one-dimensional array )
LONG DynArrayInsert( TARRAY pArray, DWORD dwIndex, LPVOID pValue );
LONG DynArrayInsertLong( TARRAY pArray, DWORD dwIndex, LONG lValue );
LONG DynArrayInsertBOOL( TARRAY pArray, DWORD dwIndex, BOOL bValue );
LONG DynArrayInsertDWORD( TARRAY pArray, DWORD dwIndex, DWORD dwValue );
LONG DynArrayInsertFloat( TARRAY pArray, DWORD dwIndex, float dwValue );
LONG DynArrayInsertDouble( TARRAY pArray, DWORD dwIndex, double dwValue );
LONG DynArrayInsertString( TARRAY pArray, DWORD dwIndex, LPCTSTR szValue, DWORD dwLength );
LONG DynArrayInsertHandle( TARRAY pArray, DWORD dwIndex, HANDLE hValue );
LONG DynArrayInsertSystemTime( TARRAY pArray, DWORD dwIndex, SYSTEMTIME stValue );
LONG DynArrayInsertFileTime( TARRAY pArray, DWORD dwIndex, FILETIME ftValue );
// helper to insert 2-dimensional array
LONG DynArrayInsertRow( TARRAY pArray, DWORD dwIndex, DWORD dwColumns );
// ( for two-dimensional array )
LONG DynArrayInsert2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, LPVOID pValue );
LONG DynArrayInsertLong2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, LONG lValue );
LONG DynArrayInsertBOOL2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, BOOL bValue );
LONG DynArrayInsertDWORD2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, DWORD dwValue );
LONG DynArrayInsertFloat2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, float dwValue );
LONG DynArrayInsertDouble2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, double dwValue );
LONG DynArrayInsertString2( TARRAY pArray, DWORD dwRow,
DWORD dwColIndex, LPCTSTR szValue, DWORD dwLength );
LONG DynArrayInsertHandle2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, HANDLE hValue );
LONG DynArrayInsertSystemTime2( TARRAY pArray, DWORD dwRow,
DWORD dwColIndex, SYSTEMTIME stValue );
LONG DynArrayInsertFileTime2( TARRAY pArray, DWORD dwRow,
DWORD dwColIndex, FILETIME ftValue );
//
// item value set function(s) ( for one-dimensional array )
BOOL DynArraySet( TARRAY pArray, DWORD dwIndex, LPVOID pValue );
BOOL DynArraySetLong( TARRAY pArray, DWORD dwIndex, LONG lValue );
BOOL DynArraySetBOOL( TARRAY pArray, DWORD dwIndex, BOOL bValue );
BOOL DynArraySetDWORD( TARRAY pArray, DWORD dwIndex, DWORD dwValue );
BOOL DynArraySetFloat( TARRAY pArray, DWORD dwIndex, float dwValue );
BOOL DynArraySetDouble( TARRAY pArray, DWORD dwIndex, double dwValue );
BOOL DynArraySetString( TARRAY pArray, DWORD dwIndex, LPCTSTR szValue, DWORD dwLength );
BOOL DynArraySetHandle( TARRAY pArray, DWORD dwIndex, HANDLE hValue );
BOOL DynArraySetSystemTime( TARRAY pArray, DWORD dwIndex, SYSTEMTIME stValue );
BOOL DynArraySetFileTime( TARRAY pArray, DWORD dwIndex, FILETIME ftValue );
// ( for two-dimensional array )
BOOL DynArraySet2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, LPVOID pValue );
BOOL DynArraySetLong2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, LONG lValue );
BOOL DynArraySetBOOL2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, BOOL bValue );
BOOL DynArraySetDWORD2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, DWORD dwValue );
BOOL DynArraySetFloat2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, float dwValue );
BOOL DynArraySetDouble2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, double dwValue );
BOOL DynArraySetString2( TARRAY pArray, DWORD dwRow,
DWORD dwColumn, LPCTSTR szValue, DWORD dwLength );
BOOL DynArraySetHandle2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, HANDLE hValue );
BOOL DynArraySetSystemTime2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, SYSTEMTIME stValue );
BOOL DynArraySetFileTime2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, FILETIME ftValue );
//
// item value get function(s) ( for one-dimensional array )
LPVOID DynArrayItem( TARRAY pArray, DWORD dwIndex );
LONG DynArrayItemAsLong( TARRAY pArray, DWORD dwIndex );
BOOL DynArrayItemAsBOOL( TARRAY pArray, DWORD dwIndex );
DWORD DynArrayItemAsDWORD( TARRAY pArray, DWORD dwIndex );
float DynArrayItemAsFloat( TARRAY pArray, DWORD dwIndex );
double DynArrayItemAsDouble( TARRAY pArray, DWORD dwIndex );
LPCTSTR DynArrayItemAsString( TARRAY pArray, DWORD dwIndex );
HANDLE DynArrayItemAsHandle( TARRAY pArrray, DWORD dwIndex );
SYSTEMTIME DynArrayItemAsSystemTime( TARRAY pArray, DWORD dwIndex );
FILETIME DynArrayItemAsFileTime( TARRAY pArray, DWORD dwIndex );
DWORD DynArrayItemAsStringEx( TARRAY pArray, DWORD dwIndex, LPTSTR szBuffer, DWORD dwLength );
// ( for two-dimensional array )
LPVOID DynArrayItem2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
LONG DynArrayItemAsLong2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
BOOL DynArrayItemAsBOOL2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
DWORD DynArrayItemAsDWORD2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
float DynArrayItemAsFloat2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
double DynArrayItemAsDouble2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
LPCTSTR DynArrayItemAsString2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
HANDLE DynArrayItemAsHandle2( TARRAY pArrray, DWORD dwRow, DWORD dwColumn );
SYSTEMTIME DynArrayItemAsSystemTime2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
FILETIME DynArrayItemAsFileTime2( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
DWORD DynArrayItemAsStringEx2( TARRAY pArray,
DWORD dwRow, DWORD dwColumn, LPTSTR szBuffer, DWORD dwLength );
//
// array item removal function(s) ( for one-dimensional array )
VOID DynArrayRemoveAll( TARRAY pArray );
BOOL DynArrayRemove( TARRAY pArray, DWORD dwIndex );
// ( for two-dimensional array )
BOOL DynArrayRemoveColumn( TARRAY pArray, DWORD dwRow, DWORD dwColumn );
//
// find value function(s) ( for one-dimensional array )
LONG DynArrayFindLong( TARRAY pArray, LONG lValue );
LONG DynArrayFindDWORD( TARRAY pArray, DWORD dwValue );
LONG DynArrayFindString( TARRAY pArray, LPCTSTR szValue, BOOL bIgnoreCase, DWORD dwCount );
LONG DynArrayFindFloat( TARRAY pArray, float fValue );
LONG DynArrayFindDouble( TARRAY pArray, double dblValue );
LONG DynArrayFindHandle( TARRAY pArray, HANDLE hValue );
LONG DynArrayFindSystemTime( TARRAY pArray, SYSTEMTIME stValue );
LONG DynArrayFindFileTime( TARRAY pArray, FILETIME ftValue );
// ( for two-dimensional array )
LONG DynArrayFindLong2( TARRAY pArray, DWORD dwRow, LONG lValue );
LONG DynArrayFindDWORD2( TARRAY pArray, DWORD dwRow, DWORD dwValue );
LONG DynArrayFindString2( TARRAY pArray, DWORD dwRow,
LPCTSTR szValue, BOOL bIgnoreCase, DWORD dwCount );
LONG DynArrayFindFloat2( TARRAY pArray, DWORD dwRow, float fValue );
LONG DynArrayFindDouble2( TARRAY pArray, DWORD dwRow, double dblValue );
LONG DynArrayFindHandle2( TARRAY pArray, DWORD dwRow, HANDLE hValue );
LONG DynArrayFindSystemTime2( TARRAY pArray, DWORD dwRow, SYSTEMTIME stValue );
LONG DynArrayFindFileTime2( TARRAY pArray, DWORD dwRow, FILETIME ftValue );
// ( for two-dimensional array ... column wise searching )
LONG DynArrayFindLongEx( TARRAY pArray, DWORD dwColumn, LONG lValue );
LONG DynArrayFindDWORDEx( TARRAY pArray, DWORD dwColumn, DWORD dwValue );
LONG DynArrayFindStringEx( TARRAY pArray, DWORD dwColumn,
LPCTSTR szValue, BOOL bIgnoreCase, DWORD dwCount );
LONG DynArrayFindFloatEx( TARRAY pArray, DWORD dwColumn, float fValue );
LONG DynArrayFindDoubleEx( TARRAY pArray, DWORD dwColumn, double dblValue );
LONG DynArrayFindHandleEx( TARRAY pArray, DWORD dwColumn, HANDLE hValue );
LONG DynArrayFindSystemTimeEx( TARRAY pArray, DWORD dwColumn, SYSTEMTIME ftValue );
LONG DynArrayFindFileTimeEx( TARRAY pArray, DWORD dwColumn, FILETIME ftValue );
//
// array attachment helpers ( one-dimensional )
LONG DynArrayAppendEx( TARRAY pArray, TARRAY pArrItem );
LONG DynArrayInsertEx( TARRAY pArray, DWORD dwIndex, TARRAY pArrItem );
BOOL DynArraySetEx( TARRAY pArray, DWORD dwIndex, TARRAY pArrItem );
// ( for two-dimensional array )
LONG DynArrayAppendEx2( TARRAY pArray, DWORD dwRow, TARRAY pArrItem );
LONG DynArrayInsertEx2( TARRAY pArray, DWORD dwRow, DWORD dwColIndex, TARRAY pArrItem );
BOOL DynArraySetEx2( TARRAY pArray, DWORD dwRow, DWORD dwColumn, TARRAY pArrItem );
///////////////////////////////////////////////////////////////////////////////
// //
// COMMONAND LINE PARSING //
// //
///////////////////////////////////////////////////////////////////////////////
//
// constants / definitions / enumerations
//
// type ( dwType )
#define CP_TYPE_TEXT 0x00000001 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 0001
#define CP_TYPE_NUMERIC 0x00000002 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 0010
#define CP_TYPE_UNUMERIC 0x00000003 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 0011
#define CP_TYPE_DATE 0x00000004 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 0100
#define CP_TYPE_TIME 0x00000005 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 0101
#define CP_TYPE_DATETIME 0x00000006 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 0110
#define CP_TYPE_FLOAT 0x00000007 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 0111
#define CP_TYPE_DOUBLE 0x00000008 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 1000
#define CP_TYPE_CUSTOM 0x00000009 // XXXX XXXX XXXX XXXX XXXX XXXX 0000 1001
#define CP_TYPE_BOOLEAN 0x0000000A // XXXX XXXX XXXX XXXX XXXX XXXX 0000 1010
#define CP_TYPE_MASK 0x000000FF // XXXX XXXX XXXX XXXX XXXX XXXX 1111 1111
//
// version 1
//
#define CP_MODE_ARRAY 0x00000100 // 0001 XXXX XXXX
#define CP_MODE_VALUES 0x00000200 // 0010 XXXX XXXX
#define CP_MODE_MASK 0x00000F00 // 1111 XXXX XXXX
#define CP_VALUE_OPTIONAL 0x00001000 // 0001 XXXX XXXX XXXX
#define CP_VALUE_MANDATORY 0x00002000 // 0010 XXXX XXXX XXXX
#define CP_VALUE_NODUPLICATES 0x00004000 // 0100 XXXX XXXX XXXX
#define CP_VALUE_NOLENGTHCHECK 0x00008000 // 1000 XXXX XXXX XXXX
#define CP_VALUE_MASK 0x0000F000 // 1111 XXXX XXXX XXXX
#define CP_MAIN_OPTION 0x00010000 // 0000 0000 0001 XXXX XXXX XXXX XXXX
#define CP_USAGE 0x00020000 // 0000 0000 0010 XXXX XXXX XXXX XXXX
#define CP_DEFAULT 0x00040000 // 0000 0000 0100 XXXX XXXX XXXX XXXX
#define CP_MANDATORY 0x00080000 // 0000 0000 1000 XXXX XXXX XXXX XXXX
#define CP_CASESENSITIVE 0x00100000 // 0000 0001 0000 XXXX XXXX XXXX XXXX
#define CP_IGNOREVALUE 0x00200000 // 0000 0010 0000 XXXX XXXX XXXX XXXX
#define CP_MASK 0x0FFF0000 // 1111 1111 1111 XXXX XXXX XXXX XXXX
//
// version 2
//
#define CP2_MODE_ARRAY 0x00000001 // XXXX XXXX XXXX XXXX XXXX XXXX XXXX 0001
#define CP2_MODE_VALUES 0x00000002 // XXXX XXXX XXXX XXXX XXXX XXXX XXXX 0010
#define CP2_MODE_MASK 0x0000000F // XXXX XXXX XXXX XXXX XXXX XXXX XXXX 1111
#define CP2_VALUE_OPTIONAL 0x00000010 // XXXX XXXX XXXX XXXX 0000 0000 0001 XXXX
#define CP2_VALUE_NODUPLICATES 0x00000020 // XXXX XXXX XXXX XXXX 0000 0000 0010 XXXX
#define CP2_VALUE_TRIMINPUT 0x00000040 // XXXX XXXX XXXX XXXX 0000 0000 0100 XXXX
#define CP2_VALUE_NONULL 0x00000080 // XXXX XXXX XXXX XXXX 0000 0000 1000 XXXX
#define CP2_VALUE_MASK 0x0000FFF0 // XXXX XXXX XXXX XXXX 1111 1111 1111 XXXX
#define CP2_ALLOCMEMORY 0x00010000 // XXXX 0000 0000 0001 XXXX XXXX XXXX XXXX
#define CP2_USAGE 0x00020000 // XXXX 0000 0000 0010 XXXX XXXX XXXX XXXX
#define CP2_DEFAULT 0x00040000 // XXXX 0000 0000 0100 XXXX XXXX XXXX XXXX
#define CP2_MANDATORY 0x00080000 // XXXX 0000 0000 1000 XXXX XXXX XXXX XXXX
#define CP2_CASESENSITIVE 0x00100000 // XXXX 0000 0001 0000 XXXX XXXX XXXX XXXX
#define CP2_MASK 0x0FFF0000 // XXXX 1111 1111 1111 XXXX XXXX XXXX XXXX
//
// user defined types
//
typedef TCHAR OPTION[ 256 ];
typedef TCHAR OPTVALUE[ 256 ];
// custom value validation routine prototype
typedef BOOL ( *PARSERFUNC )( LPCWSTR pwszOption, LPCWSTR pwszValue, LPVOID pData );
typedef BOOL ( *PARSERFUNC2 )( LPCWSTR pwszOption, LPCWSTR pwszValue, LPVOID pData, DWORD* pdwIncrement );
// command line parser -- version 1
typedef struct __tagCmdParser
{
OPTION szOption; // options
DWORD dwFlags; // flags ( specifies the type etc )
DWORD dwCount; // tells the no. of times the option can repeat
DWORD dwActuals; // no. of times the option actually repeated
LPVOID pValue; // pointer to the option value
OPTVALUE szValues; // to hold valid value in case flag = CP_MODE_VALUES
PARSERFUNC pFunction; // pointer to custom value validation function
LPVOID pFunctionData; // extra data that will be passed to custom function
} TCMDPARSER;
typedef TCMDPARSER* PTCMDPARSER;
extern const CHAR cszParserSignature[ 8 ];
// command line parser version 2
typedef struct __tagCmdParser2
{
CHAR szSignature[ 8 ]; // should always be "PARSER2\0"
DWORD dwType; // type of the argument
DWORD64 dwFlags; // flags
DWORD dwCount; // tells the no. of times the option can repeat
DWORD dwActuals; // no. of times the option actually repeated
LPCWSTR pwszOptions; // options
LPCWSTR pwszFriendlyName; // specifies friendly name for the option
LPCWSTR pwszValues; // to hold valid value in case flag = CP_MODE_VALUES
// format that can be used for this
// CP_TYPE_TEXT apple|orange|banana
// ********************************************
// CP_TYPE_NUMERIC 1,100;105;200,256;1000,
// CP_TYPE_UNUMERIC (this example tells
// argument can be any
// number from 1 to 100
// or 105 or 200 or
// 256 or any value
// greater than or
// equal to 1000
LPVOID pValue; // pointer to the option value
DWORD dwLength; // max. length of argument value that can be stored
// valid only for CP_TYPE_TEXT
PARSERFUNC2 pFunction; // pointer to custom value validation function
LPVOID pFunctionData; // extra data that will be passed to custom function
DWORD dwReserved; // reserver for future use
LPVOID pReserved1; // reserved for future use
LPVOID pReserved2; // reserved for future use
LPVOID pReserved3; // reserved for future use
} TCMDPARSER2;
typedef TCMDPARSER2* PTCMDPARSER2;
BOOL DoParseParam2( DWORD dwCount,
LPCWSTR argv[],
LONG lSubOptionIndex,
DWORD dwOptionsCount,
PTCMDPARSER2 pcmdOptions,
DWORD dwReserved );
//
// public function prototypes
//
LONG GetOptionCount( LPCTSTR szOption,
DWORD dwCount, PTCMDPARSER pcmdOptions );
BOOL DoParseParam( DWORD dwCount,
LPCTSTR argv[],
DWORD dwOptionsCount,
PTCMDPARSER pcmdOptions );
///////////////////////////////////////////////////////////////////////////////
// //
// VALIDATING AND FILTERING RESULTS //
// //
///////////////////////////////////////////////////////////////////////////////
//
// constants / definitions / enumerations
//
// types
#define F_TYPE_TEXT 0x00000001 // 0000 0000 0001
#define F_TYPE_NUMERIC 0x00000002 // 0000 0000 0010
#define F_TYPE_UNUMERIC 0x00000003 // 0000 0000 0011
#define F_TYPE_DATE 0x00000004 // 0000 0000 0100
#define F_TYPE_TIME 0x00000005 // 0000 0000 0101
#define F_TYPE_DATETIME 0x00000006 // 0000 0000 0110
#define F_TYPE_FLOAT 0x00000007 // 0000 0000 0111
#define F_TYPE_DOUBLE 0x00000008 // 0000 0000 1000
#define F_TYPE_CUSTOM 0x00000009 // 0000 0000 1001
#define F_TYPE_MASK 0x00000FFF // 1111 1111 1111
// modes
#define F_MODE_VALUES 0x00001000 // 0001 XXXX XXXX XXXX
#define F_MODE_PATTERN 0x00002000 // 0010 XXXX XXXX XXXX
#define F_MODE_ARRAY 0x00004000 // 0100 XXXX XXXX XXXX
// custom filter data validation result
#define F_FILTER_INVALID 0x00000000
#define F_FILTER_VALID 0x00000001
#define F_RESULT_KEEP 0x000000FF
#define F_RESULT_REMOVE 0x00000000
//
// Bit no. 2 is '='
// Bit no. 3 is '<'
// Bit no. 4 is '>'
//
// 7654 3210
// EQ 0000 0010 0x02
// NE 1111 XX0X 0xFD
// LT 0000 0100 0x04
// GT 0000 1000 0x08
// LE 0000 0110 0x06
// GE 0000 1010 0x0A
//
#define MASK_EQ 0x00000002
#define MASK_NE 0x000000FC
#define MASK_LT 0x00000004
#define MASK_GT 0x00000008
#define MASK_LE 0x00000006
#define MASK_GE 0x0000000A
#define MASK_ALL 0x000000FF
// mathematical operators
#define MATH_EQ _T( "=" )
#define MATH_NE _T( "!=" )
#define MATH_LT _T( "<" )
#define MATH_GT _T( ">" )
#define MATH_LE _T( "<=" )
#define MATH_GE _T( ">=" )
// parsed filters information
#define F_PARSED_INDEX_FILTER 0
#define F_PARSED_INDEX_PROPERTY 1
#define F_PARSED_INDEX_OPERATOR 2
#define F_PARSED_INDEX_VALUE 3
#define F_PARSED_INFO_COUNT 4
//
// structures / user defined data types
//
typedef TCHAR OPERATORS[ 101 ];
typedef TCHAR FILTERVALUES[ 256 ];
typedef TCHAR FILTERPROPERTY[ 256 ];
// custom value validation routine prototype
typedef DWORD ( *FILTERFUNC )( LPCTSTR pszProperty, LPCTSTR pszOperator,
LPCTSTR pszValue, LPVOID pData, TARRAY arrRow );
typedef struct __tagFilterConfig
{
DWORD dwColumn; // mapping from filter to column in data
FILTERPROPERTY szProperty; // filter property
OPERATORS szOperators; // valid operators for the filter
DWORD dwFlags; // flags ( specifies the valid type for the filter )
FILTERVALUES szValues; // to hold valid value in case flag = F_MODE_VALUES
FILTERFUNC pFunction; // pointer to custom value validation function
LPVOID pFunctionData; // extra data that will be passed to custom function
} TFILTERCONFIG;
typedef TFILTERCONFIG *PTFILTERCONFIG;
//
// public function prototypes
//
LPCTSTR FindOperator( LPCTSTR szOperator );
BOOL ParseAndValidateFilter( DWORD dwCount,
PTFILTERCONFIG pfilterConfigs,
TARRAY arrFiltersArgs, PTARRAY parrParsedFilters );
BOOL CanFilterRecord( DWORD dwCount,
TFILTERCONFIG filterConfigs[],
TARRAY arrRecord, TARRAY arrParsedFilters );
DWORD FilterResults( DWORD dwCount,
TFILTERCONFIG arrFilters[],
TARRAY arrData, TARRAY arrParsedFilters );
///////////////////////////////////////////////////////////////////////////////
// //
// DISPLAYING RESULTS //
// //
///////////////////////////////////////////////////////////////////////////////
//
// constants / definitions / enumerations
//
// formats
#define SR_FORMAT_LIST 0x00000001 // 0000 0001
#define SR_FORMAT_TABLE 0x00000002 // 0000 0010
#define SR_FORMAT_CSV 0x00000003 // 0000 0011
#define SR_FORMAT_MASK 0x0000000F // 1111 1111
// column types
#define SR_TYPE_NONE 0x00000000 // 0000 0000 0000 0000 XXXX XXXX
#define SR_TYPE_STRING 0x00000010 // 0000 0000 0000 0001 XXXX XXXX
#define SR_TYPE_NUMERIC 0x00000020 // 0000 0000 0000 0010 XXXX XXXX
#define SR_TYPE_FLOAT 0x00000030 // 0000 0000 0000 0011 XXXX XXXX
#define SR_TYPE_DOUBLE 0x00000040 // 0000 0000 0000 0100 XXXX XXXX
#define SR_TYPE_DATE 0x00000050 // 0000 0000 0000 0101 XXXX XXXX
#define SR_TYPE_TIME 0x00000060 // 0000 0000 0000 0110 XXXX XXXX
#define SR_TYPE_DATETIME 0x00000070 // 0000 0000 0000 0111 XXXX XXXX
#define SR_TYPE_CUSTOM 0x00000080 // 0000 0000 0000 1000 XXXX XXXX
#define SR_TYPE_MASK 0x00000FF0 // 1111 1111 1111 1111 XXXX XXXX
// flags ( global level )
#define SR_NOHEADER 0x00001000 // 0000 0001 XXXX XXXX XXXX XXXX XXXX XXXX
// flags ( column level )
#define SR_HIDECOLUMN 0x00001000 // 0000 0000 0001 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_VALUEFORMAT 0x00002000 // 0000 0000 0010 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_ARRAY 0x00004000 // 0000 0000 0100 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_WORDWRAP 0x00008000 // 0000 0000 1000 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_ALIGN_LEFT 0x00010000 // 0000 0001 0000 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_ALIGN_RIGHT 0x00020000 // 0000 0010 0000 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_ALIGN_CENTER 0x00040000 // 0000 0100 0000 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_NO_TRUNCATION 0x00088000 // 0000 1000 1000 XXXX XXXX XXXX XXXX XXXX XXXX
#define SR_SHOW_NA_WHEN_BLANK 0x00100000 // 0001 0000 0000 XXXX XXXX XXXX XXXX XXXX XXXX
//
// user defined types
//
// custom value formatter
typedef TCHAR COLHEADER[ 256 ];
typedef TCHAR COLFORMAT[ 65 ];
typedef VOID ( *FORMATFUNC )( DWORD dwColumn, TARRAY arrData, LPVOID pData, LPTSTR szValue );
typedef struct __tagColumns
{
COLHEADER szColumn; // column header name
DWORD dwWidth; // width of each field
DWORD dwFlags; // flags ( specifies the type etc )
COLFORMAT szFormat; // custom format
FORMATFUNC pFunction; // formatter function
LPVOID pFunctionData; // function data
} TCOLUMNS;
typedef TCOLUMNS* PTCOLUMNS;
//
// public functions
//
VOID ShowResults( DWORD dwColumns, PTCOLUMNS pColumns, DWORD dwFlags, TARRAY arrData );
///////////////////////////////////////////////////////////////////////////////////
// COMING UP *** DO NOT USE UNLESS INTIMATED //
///////////////////////////////////////////////////////////////////////////////////
VOID ShowResults2( FILE* fp, DWORD dwColumns, PTCOLUMNS pColumns, DWORD dwFlags, TARRAY arrData );
///////////////////////////////////////////////////////////////////////////////////
#ifdef __cplusplus
}
#endif
#endif // __CMDLINE_H