Windows-Server-2003/sdktools/gutils/gutils.h

352 lines
13 KiB
C

/* standard header for gutils.dll library functions
* include after windows.h
*/
#define DimensionOf(x) (sizeof(x) / sizeof(x[0]))
/*--------win-16 win-32 porting macros etc ----------------------------*/
/* win32 msg crackers */
#define GET_WM_COMMAND_ID(w, l) (LOWORD(w))
#define GET_WM_COMMAND_CMD(w, l) (HIWORD(w))
#define GET_WM_COMMAND_HWND(w, l) (l)
#define GET_SCROLL_OPCODE(w, l) (LOWORD(w))
#define GET_SCROLL_POS(w, l) (HIWORD(w))
/* use of WNDPROC and FARPROC don't match up in definitions of
* Win 3.1 functions vs NT functions. WINPROCTYPE matches WNDPROC
* in NT and FARPROC in Win 3.1 so there are no warnings in either.
* Places that use FARPROC in both APIs continue to use FARPROC.
*/
#define WINPROCTYPE WNDPROC
// #define DLGPROC WNDPROC Doesn't wash on MIPS!!
/* ------- memory allocator ------------------------------------------*/
/* global heap functions - allocate and free many small
* pieces of memory by calling global alloc for large pieces -
* avoids using too many selectors
*
* DOGMA:
* If you go running things on different threads and then try to EXIT
* and hence gmem_free everything on one thread while still allocating
* and hooking things up on another, things can get a little out of hand!
* In particular, you may traverse a structure and hence try to FREE
* a sub-structure to which there is a pointer, but which itself is not yet
* allocated!
*
* The dogma is that when you allocate a new structure and tie it into a List
* or whatever
* EITHER all pointers within the allocated structure are made NULL
* before it is chained in
* OR the caller of Gmem services undertakes not to try to free any
* garbage pointers that are not yet quite built.
* It is SAFE to attempt to gmem_free a NULL pointer. It's a no-op.
* Note that List_NewXxxx(...) zeros the storage before chaining it in.
* Note that List_AddXxxx(...) obviously doesn't!
*/
HANDLE APIENTRY gmem_init(void);
LPSTR APIENTRY gmem_get(HANDLE hHeap, int len);
void APIENTRY gmem_free(HANDLE hHeap, LPSTR ptr, int len);
void APIENTRY gmem_freeall(HANDLE hHeap);
/* return total time consumed doing gmem_get */
LONG APIENTRY gmem_time(void);
/* ---- file open/save common dialogs ---------------------------*/
/*
* these functions now rely on to calls to the common dialog libraries.
*
* parameters:
* prompt - user prompt text (eg for dialog title)
* ext - default extension (eg ".txt")
* spec - default file spec (eg "*.*")
* pszFull - full filename will be copied here.
* cchMax - size of pszFull buffer.
* fn - last component of file name will be copied here.
* returns - TRUE if user selected a file that could be opened for
* reading (gfile_open) or created and opened for writing (gfile_new)
* FALSE if user canceled. if user selects a file that cannot be
* opened, a message box is put up and the dialog re-shown.
*/
BOOL APIENTRY gfile_open(HWND hwnd, LPSTR prompt, LPSTR ext, LPSTR spec,
LPSTR pszFull, int cchMax, LPSTR fn);
BOOL APIENTRY gfile_new(LPSTR prompt, LPSTR ext, LPSTR spec,
LPSTR pszFull, int cchMax, LPSTR fn);
/* --------- date conversion functions -----------------------*/
/* days (which is actually days measured from a notional Jan 1st 0000)
is a convenient way to store the date in a single LONG. Use
dmytoday to generate the LONG, use daytodmy to convert back
*/
void APIENTRY gdate_daytodmy(LONG days,
int FAR* yrp, int FAR* monthp, int FAR* dayp);
LONG APIENTRY gdate_dmytoday(int yr, int month, int day);
/* number of days in given month (Jan===1) in given year (e.g. 1993) */
int APIENTRY gdate_monthdays(int month, int year);
/* daynr is our standard LONG day number. Returns day of the week.
Weekdays are numbered from 0 to 6, Sunday==0
*/
int APIENTRY gdate_weekday(long daynr);
/* --- status line window class ---------------------------------- */
/* The status line is a bar across the top or bottom of the window.
* It can hold a number of fields which can be either static text
* or buttons. The so called "static" text can be changed at any time.
* The fields can be left or right aligned (default is RIGHT).
* If the text is marked as VAR then the screen real estate allocated
* for it will be adjusted whenever the text changes. VAR fields
* can be given minimum or maximum sizes (but not both).
*
* STATIC text fields can be drawn as raised or lowered rectangles (using
* shades of grey), or (default) without a border. BUTTON fields will
* always be drawn as raised rectangles, and will lower when pressed.
*
* Button fields will send WM_COMMAND messages when clicked including the
* field id and the WM_LBUTTONUP notification code. Note that that this
* is not a full implementation of the button class, and no other messages
* will be sent. In general, none of the fields of a status bar are
* implemented as separate windows, so GetDlgItem() and similar calls will not
* work. Buttons only respond to mouse down events, and there is no handling
* of the focus or of keyboard events.
*
* To use:
* call StatusAlloc giving the number of items you are going to add to the
* status bar. This returns a handle to use in subsequent calls.
*
* Then call StatusAddItem to define each item in turn.
* Buttons are placed in order of definition along the bar starting from
* the left (SF_LEFT) and from the right (SF_RIGHT) until the two
* sides meet.
*
* Call StatusHeight to find the expected height of this status bar, and
* set its position within the parent window, then call StatusCreate to
* create the window.
*
* Having created the window, send SM_SETTEXT messages to set the new
* text of a field (static or button), or SM_NEW with a handle (obtained from
* StatusAlloc) to change the contents of the status line.
*/
/* values for type argument to StatusAddItem */
#define SF_BUTTON 1
#define SF_STATIC 2
/* bits in flags argument to StatusAddItem */
#define SF_RAISE 1 /* paint static as raised 3D rectangle */
#define SF_LOWER 2 /* paint static as lowered 3D rectangle */
#define SF_LEFT 4 /* align field on left of status bar */
#define SF_RIGHT 8 /* align field on right (DEFAULT) */
#define SF_VAR 0x10 /* size of field depends on actual text extent*/
#define SF_SZMAX 0x20 /* (with SF_VAR): width argument is maximum */
#define SF_SZMIN 0x40 /* (with SF_VAR) width arg is minimum size */
/* interfaces */
HWND APIENTRY StatusCreate(HANDLE hInst, HWND hParent, INT_PTR id,
LPRECT rcp, HANDLE hmem);
/* return the recommended height in device units of the given status bar */
int APIENTRY StatusHeight(HANDLE hmem);
/* alloc the status bar data structures and return handle*/
HANDLE APIENTRY StatusAlloc(int nitems);
/* set the attributes of a field.
*
* hmem obtained from StatusAlloc. itemnr must be less than the nitems
* passed to StatusAlloc.
*
* the width argument is the width of the field in characters (average
* character width).
*/
BOOL APIENTRY StatusAddItem(HANDLE hmem, int itemnr, int type, int flags,
int id, int width, LPSTR text);
/* send these window messages to the class */
#define SM_NEW (WM_USER+1) /* wParam handle for new status line */
#define SM_SETTEXT (WM_USER+2) /* wparam: item id, lparam new label*/
/* --- bit-map freelist management functions -------------------------------*/
/* init a pre-allocated array of longs to map nblks - set all to free
you should allocate 1 DWORD in map for every 32 blocks of storage
you wish to control.
*/
void APIENTRY gbit_init(DWORD FAR * map, long nblks);
/* mark a range of nblks starting at blknr to be busy */
BOOL APIENTRY gbit_alloc(DWORD FAR * map, long blknr, long nblks);
/* mark a range of nblks starting at blknr to be free */
BOOL APIENTRY gbit_free(DWORD FAR * map, long blknr, long nblks);
/* find a free section nblks long, or the biggest found in the map if all
* are less than nblks long. returns size of region found as return value,
* and sets blknr to the starting blk of region. Region is *not* marked
* busy
*/
long APIENTRY gbit_findfree(DWORD FAR* map, long nblks,
long mapsize, long FAR * blknr);
/* ----- buffered line input ----------------------------------*/
/*
* functions for reading a file, one line at a time, with some buffering
* to make the operation reasonably efficient.
*
* call readfile_new to initialise the buffer and give it a handle to
* an open file. Call readfile_next to get a pointer to the next line.
* This discards the previous line and gives you a pointer to the line
* IN THE BUFFER. Make your own copy before calling readfile_next again.
*
* call readfile_delete once you have finished with this file. That will close
* the file and free up any memory.
*/
// MAX_LINE_LENGTH is the max number of physical characters we allow in a line
#define MAX_LINE_LENGTH (4096)
// BUFFER_SIZE is expressed in bytes, and is large enough to read in
// MAX_LINE_LENGTH wide chars, and also hold MAX_LINE_LENGTH 5-byte hex code
// representations of the chars.
#define BUFFER_SIZE (MAX_LINE_LENGTH * 5)
/* handle to a file buffer */
typedef struct filebuffer FAR * FILEBUFFER;
/* initialise the buffering for an open file */
FILEBUFFER APIENTRY readfile_new(HANDLE fh, BOOL *pfUnicode);
/* return a pointer to the next line in this file. line must be shorter than
* buffer size (currently 1024 bytes). Line is not null-terminated: *plen
* is set to the length of the line including the \n. This call will
* discard any previous line, so ensure that you have made a copy of one line
* before you call readfile_next again.
* MUST CALL readfile_setdelims FIRST!
*/
LPSTR APIENTRY readfile_next(FILEBUFFER fb, int FAR * plen, LPWSTR *ppwz, int *pcwch);
/* set the delimiters to use to break lines. MUST call this to initialise */
void APIENTRY readfile_setdelims(LPBYTE str);
/*
* close the file and discard any associated memory and buffers.
*/
void APIENTRY readfile_delete(FILEBUFFER fb);
/* ------ hashing and checksums ------------------------------------------- */
/*
* generate a 32-bit hash code for a null-terminated string of ascii text.
*
* if bIgnoreBlanks is TRUE, we ignore spaces and tabs during the
* hashcode calculation.
*/
/* hash codes are unsigned longs */
DWORD APIENTRY hash_string(LPSTR string, BOOL bIgnoreBlanks);
void Format(char * a, char * b);
/* return TRUE iff the string is blank. Blank means the same as
* the characters which are ignored in hash_string when ignore_blanks is set
*/
BOOL APIENTRY utils_isblank(LPSTR string);
/*
* Compare two pathnames, and if not equal, decide which should come first.
*
* returns 0 if the same, -1 if left is first, and +1 if right is first.
*
* The comparison is such that all filenames in a directory come before any
* file in a subdirectory of that directory.
*
* To make absolutely certain that you get a canonical sorting, use AnsiLowerBuff
* to convert BOTH to lower case first. You may get a funny effect if one one
* has been converted to lower case and the other not.
*/
int APIENTRY
utils_CompPath(LPSTR left, LPSTR right);
/* given an open file handle open for reading, read the file and
* generate a 32-bit checksum for the file
*/
/* checksums are unsigned longs */
typedef DWORD CHECKSUM;
/* Open a file, checksum it and close it again. err !=0 iff it failed. */
CHECKSUM APIENTRY checksum_file(LPCSTR fn, LONG FAR * err);
/* --- error message output ----------------------------------------------*/
/*
* reports error in a dialog, returns TRUE for ok, FALSE for cancel.
* if fCancel is FALSE, only the OK button is shown, otherwise both ok
* and cancel. hwnd is the parent window for the dlg. can be null.
*/
BOOL APIENTRY Trace_Error(HWND hwnd, LPSTR msg, BOOL fCancel);
/* Write popups to a file until further notice */
void Trace_Unattended(BOOL bUnattended);
/* --- create/write to trace file ----------------------------------------*/
void APIENTRY Trace_File(LPSTR msg);
/* --- close trace file --------------------------------------------------*/
void APIENTRY Trace_Close(void);
/* --- simple input ------------------------------------------------------*/
/*
* input of a single text string, using a simple dialog.
*
* returns TRUE if ok, or FALSE if error or user canceled. If TRUE,
* puts the string entered into result (up to resultsize characters).
*
*
* prompt is used as the prompt string, caption as the dialog caption and
* def_input as the default input. All of these can be null.
*/
int APIENTRY StringInput(LPSTR result, int resultsize, LPSTR prompt,
LPSTR caption, LPSTR def_input);
/* --- sockets -----------------------------------------------------------*/
#ifdef SOCKETS
#include <winsock.h>
BOOL SocketConnect( LPSTR pstrServerName, u_short TCPPort, SOCKET *pSocket );
BOOL SocketListen( u_short TCPPort, SOCKET *pSocket );
#endif
// These are for both WINDIFF.EXE and GUTILS.DLL.
//#define strchr My_mbschr
//#define strncpy My_mbsncpy
PUCHAR My_mbspbrk(PUCHAR, PUCHAR);
LPSTR My_mbschr(LPCSTR, unsigned short);
LPSTR My_mbsncpy(LPSTR, LPCSTR, size_t);
// These are for WINDIFF.EXE.
//#define strrchr My_mbsrchr
//#define strncmp My_mbsncmp
LPSTR My_mbsrchr(LPCSTR, unsigned short);
int My_mbsncmp(LPCSTR, LPCSTR, size_t);
LPTSTR APIENTRY LoadRcString(UINT);