2020-09-30 16:53:55 +02:00

297 lines
7.0 KiB
C

/*++
Copyright (c) 1991-1992 Microsoft Corporation
Module Name:
StrArray.c
Abstract:
This is the a header file of handy functions and macros for TCHAR
string arrays.
These arrays are in the following format (spaces added for clarity):
one \0 two \0 three \0 \0
where \0 is a null character in the appropriate format.
These functions are useful for the NetServerDiskEnum and NetConfigGetAll
APIs, and possibly others.
Author:
John Rogers (JohnRo) 24-Oct-1991
Environment:
Portable to any flat, 32-bit environment. (Uses Win32 typedefs.)
Requires ANSI C extensions: slash-slash comments, long external names.
Note:
This function assumes that the machine's default codepage is the same
as the LAN's default codepage.
Revision History:
24-Oct-1991 JohnRo
Created.
02-Jan-1992 JohnRo
Moved my RxpCopyStrArrayToTStrArray() from RxCommon to NetLib,
and renamed it. Added some other random functions.
30-Jan-1992 JohnRo
Fixed off-by-one bug in NetpAddTStrToTStrArray().
Enhanced handling of "empty" TCHAR string arrays.
Use TCHAR_EOS equate.
05-Jun-1992 JohnRo
RAID 11253: NetConfigGetAll fails when remoted to downlevel.
01-Sep-1992 JohnRo
RAID 5016: NetConfigGetAll heap trash.
--*/
// These must be included first:
#include <windef.h> // IN, VOID, LPWSTR, etc.
#include <lmcons.h> // (Needed by NetLib.h)
// These can be in any order:
#include <netlib.h> // NetpPointerPlusSomeBytes().
#include <netdebug.h> // NetpAssert(), etc.
#include <strarray.h> // LPTSTR_ARRAY, my prototypes.
#include <string.h> // strlen() for codepage strings.
#include <tstring.h> // NetpCopyStrToTStr(), TCHAR_EOS.
//
//////////////////////////////// LPTSTR_ARRAY stuff //////////////////////////
//
VOID
NetpAddTStrToTStrArray (
IN OUT LPTSTR_ARRAY DestArray,
IN LPTSTR Src
)
{
DWORD AddSize; // byte count (including null char) of string being added
LPTSTR DestStringStart;
DWORD NewArraySize;
DWORD OldArraySize;
NetpAssert( DestArray != NULL );
NetpAssert( Src != NULL );
OldArraySize = NetpTStrArraySize( DestArray ); // May be 0.
NetpAssert( STRLEN(Src) > 0 ); // We couldn't tell from end of array.
AddSize = STRSIZE( Src );
NewArraySize = OldArraySize + AddSize;
NetpAssert( NewArraySize > 0 ); // We couldn't tell from end of array.
//
// Figure-out where new string would start. Note that OldArraySize
// includes the null char which was the end of the array, so we have
// to subtract a character to start the new one where that null char is.
//
DestStringStart = (LPTSTR)
NetpPointerPlusSomeBytes( DestArray, OldArraySize-sizeof(TCHAR) );
NetpAssert( DestStringStart != NULL );
(void) STRCPY(
DestStringStart, // dest
Src); // src
// Mark end of array.
DestArray[NewArraySize/sizeof(TCHAR)-1] = TCHAR_EOS;
NetpAssert( ! NetpIsTStrArrayEmpty( DestArray ) );
} // NetpAddTStrToTStrArray
VOID
NetpCopyStrArrayToTStrArray(
OUT LPTSTR_ARRAY Dest, // string array: TCHARs
IN LPSTR Src // string array: 8-bit input in default codepage for LAN
)
/*++
Routine Description:
NetpCopyStrArrayToTStrArray copies an array of strings (in some codepage)
to an array of strings (in TCHAR format).
These arrays are in the following format (spaces added for clarity):
one \0 two \0 three \0 \0
where \0 is a null character in the appropriate format.
This function is useful for the NetServerDiskEnum and NetConfigGetAll
APIs, and possibly others.
Arguments:
Dest - is an LPTSTR_ARRAY indicating where the converted characters are to
go. This area must be large enough to hold the data.
Src - is an LPSTR array indicating the source strings. This must be an
array of strings in the default codepage of the LAN.
Return Value:
None.
--*/
{
NetpAssert( Dest != NULL );
NetpAssert( Src != NULL );
//
// Loop for each string in the array.
//
while ( (*Src) != '\0' ) {
DWORD SrcByteCount = strlen(Src)+1; // Bytes for this codepage str.
//
// Copy one string.
//
NetpCopyStrToTStr( Dest, Src ); // Copy and conv to TCHARs.
Dest = (LPVOID) ( ((LPBYTE)Dest) + (SrcByteCount * sizeof(TCHAR)) );
Src += SrcByteCount;
}
*Dest = '\0'; // Indicate end of array.
} // NetpCopyStrArrayToTStrArray
#if DBG
// Caller is assumed to have displayed a prefix and/or other identifying
// text.
VOID
NetpDisplayTStrArray (
IN LPTSTR_ARRAY Array
)
{
LPTSTR CurrentEntry = (LPVOID) Array;
NetpAssert( Array != NULL );
if (*CurrentEntry == TCHAR_EOS) {
NetpKdPrint((" (empty)\n"));
} else {
while (*CurrentEntry != TCHAR_EOS) {
NetpKdPrint((" " FORMAT_LPTSTR "\n", (LPTSTR) CurrentEntry));
CurrentEntry += ( STRLEN( CurrentEntry ) + 1 );
}
}
} // NetpDisplayTStrArray
#endif // DBG
DWORD
NetpTStrArrayEntryCount (
IN LPTSTR_ARRAY Array
)
{
DWORD EntryCount = 0;
LPTSTR Entry = (LPVOID) Array;
NetpAssert( Array != NULL );
//
// Loop for each string in the array.
//
while ( (*Entry) != TCHAR_EOS ) {
++EntryCount;
Entry += STRLEN(Entry)+1;
}
return (EntryCount);
} // NetpTStrArrayEntryCount
DWORD
NetpTStrArraySize(
IN LPTSTR_ARRAY Array
)
{
DWORD ArrayByteCount = 0;
LPTSTR Entry = (LPVOID) Array;
NetpAssert( Array != NULL );
//
// Loop for each string in the array.
//
while ( (*Entry) != TCHAR_EOS ) {
DWORD EntryByteCount = STRSIZE(Entry); // This entry and its null.
ArrayByteCount += EntryByteCount;
Entry = (LPTSTR)NetpPointerPlusSomeBytes(Entry, EntryByteCount);
}
ArrayByteCount += sizeof(TCHAR); // Indicate end of array.
return (ArrayByteCount);
} // NetpTStrArraySize
//
//////////////////////////////// LPSTR_ARRAY stuff //////////////////////////
//
DWORD
NetpStrArraySize(
IN LPSTR_ARRAY Array
)
{
DWORD ArrayByteCount = 0;
LPSTR Entry = (LPVOID) Array;
NetpAssert( Array != NULL );
//
// Loop for each string in the array.
//
while ( (*Entry) != '\0' ) {
DWORD EntryByteCount = strlen(Entry)+1; // This entry and its null.
ArrayByteCount += EntryByteCount;
Entry = (LPSTR)NetpPointerPlusSomeBytes(Entry, EntryByteCount);
}
ArrayByteCount += sizeof(CHAR); // Indicate end of array.
return (ArrayByteCount);
} // NetpStrArraySize