|
|
// INCLUSION PREVENTION DEFINITIONS
#define NOMETAFILE
#define NOMINMAX
#define NOSOUND
#define NOPROFILER
#define NODEFERWINDOWPOS
#define NODRIVERS
#define NOCOMM
#define NOBITMAP
#define NOSCROLL
#define NOWINOFFSETS
#define NOWH
#define NORASTEROPS
#define NOOEMRESOURCE
#define NOGDICAPMASKS
#define NOKEYSTATES
#define NOSYSCOMMANDS
#define NOATOM
#define NOLOGERROR
#define NOSYSTEMPARAMSINFO
#include <windows.h>
#ifdef RLWIN32
#include <windowsx.h>
#endif
#include <commdlg.h>
#include <shellapi.h>
#include <stdio.h>
#include <stdlib.h>
#include "windefs.h"
#include "toklist.h"
#include "RLADMIN.H"
#include "RESTOK.H"
#include "update.h"
#include "custres.h"
#include "exe2res.h"
#include "commbase.h"
#include "wincomon.h"
#include "projdata.h"
#include "showerrs.h"
#include "resread.h"
#include "langlist.h"
#include "resource.h"
// Global Variables:
extern BOOL gbMaster; extern MSTRDATA gMstr; extern PROJDATA gProj; extern UCHAR szDHW[];
extern BOOL bRLGui;
#ifdef WIN32
HINSTANCE hInst; // Instance of the main window
#else
HWND hInst; // Instance of the main window
#endif
int nUpdateMode = 0; BOOL fCodePageGiven = FALSE; //... Set to TRUE if -p arg given
CHAR szFileTitle[14] = ""; // holds base name of latest opened file
CHAR szCustFilterSpec[MAXCUSTFILTER]=""; // custom filter buffer
HWND hMainWnd = NULL; // handle to main window
HWND hListWnd = NULL; // handle to tok list window
HWND hStatusWnd = NULL; // handle to status windows
static int iLastBox = IDD_SOURCERES; static CHAR * gszHelpFile = "rltools.hlp"; static TCHAR szSearchType[80] = TEXT(""); static TCHAR szSearchText[4096] = TEXT(""); static WORD wSearchStatus = 0; static WORD wSearchStatusMask = 0; static BOOL fSearchDirection; static BOOL fSearchStarted = FALSE; static BOOL fLanguageGiven = FALSE; static BOOL fLangSelected = FALSE;
static void DrawLBItem( LPDRAWITEMSTRUCT lpdis); static void MakeStatusLine( TOKEN *pTok); static BOOL SaveMtkList( HWND hWnd, FILE *fpTokFile); static TOKENDELTAINFO FAR *InsertMtkList( FILE * fpTokFile); static void CleanDeltaList( void);
static long lFilePointer[30];
// File IO vars
static OPENFILENAMEA ofn;
static CHAR szFilterSpec [60] = ""; static CHAR szExeFilterSpec [60] = ""; static CHAR szDllFilterSpec [60] = ""; static CHAR szResFilterSpec [60] = ""; static CHAR szExeResFilterSpec [180] = ""; static CHAR szMtkFilterSpec [60] = ""; static CHAR szMPJFilterSpec [60] = ""; static CHAR szRdfFilterSpec [60] = "";
static CHAR szFileName[MAXFILENAME] = "";// holds full name of latest opened file
static TCHAR tszAppName[100] = TEXT(""); static CHAR szAppName[100] = ""; static TCHAR szClassName[]=TEXT("RLAdminClass"); static TCHAR szStatusClass[]=TEXT("RLAdminStatus");
static BOOL fMtkChanges = FALSE; // set to true when toke file is out of date
static BOOL fMtkFile = FALSE; static BOOL fMpjChanges = FALSE; static BOOL fMPJOutOfDate = FALSE; static BOOL fPRJOutOfDate = FALSE;
static CHAR szOpenDlgTitle[80] = ""; // title of File open dialog
static CHAR szSaveDlgTitle[80] = ""; // title of File saveas dialog
static CHAR szNewFileName[MAXFILENAME] = ""; static CHAR szPrompt[80] = ""; static CHAR *szFSpec = NULL; static CHAR *szExt = NULL;
static TOKENDELTAINFO FAR *pTokenDeltaInfo; // linked list of token deta info
// Window vars
static HCURSOR hHourGlass = NULL; // handle to hourglass cursor
static HCURSOR hSaveCursor = NULL; // current cursor handle
static HACCEL hAccTable = NULL; static RECT Rect = {0,0,0,0}; // dimension of the client window
static UINT cyChildHeight = 0; // height of status windows
// NOTIMPLEMENTED is a macro that displays a "Not implemented" dialog
#define NOTIMPLEMENTED {\
LoadString(hInst,IDS_NOT_IMPLEMENTED,szDHW, DHWSIZE);\ MessageBox(hMainWnd,szDHW,tszAppName,MB_ICONEXCLAMATION | MB_OK);}
// Edit Tok Dialog
static FARPROC lpTokEditDlg = NULL; static HWND hTokEditDlgWnd = 0;
/**
* * * Function: InitApplication * Regsiters the main window, which is a list box composed of tokens * read from the token file. Also register the status window. * * * Arguments: * hInstance, instance handle of program in memory. * * Returns: * * Errors Codes: * TRUE, windows registered correctly. * FALSE, error during register of one of the windows. * * History: * 9/91, Implemented. TerryRu * * **/
BOOL InitApplication(HINSTANCE hInstance) { WNDCLASS wc; CHAR sz[60] = ""; CHAR sztFilterSpec[180] = "";
gbMaster=TRUE;
LoadStrIntoAnsiBuf(hInstance,IDS_RESSPEC,sz,sizeof(sz)); szFilterSpecFromSz1Sz2(szResFilterSpec,sz,"*.RES");
LoadStrIntoAnsiBuf(hInstance,IDS_EXESPEC,sz,sizeof(sz)); szFilterSpecFromSz1Sz2(szExeFilterSpec,sz,"*.EXE");
LoadStrIntoAnsiBuf(hInstance,IDS_DLLSPEC,sz,sizeof(sz)); szFilterSpecFromSz1Sz2(szDllFilterSpec,sz,"*.DLL"); CatSzFilterSpecs(sztFilterSpec,szExeFilterSpec,szDllFilterSpec); CatSzFilterSpecs(szExeResFilterSpec,sztFilterSpec,szResFilterSpec);
LoadStrIntoAnsiBuf(hInstance,IDS_MTKSPEC,sz,sizeof(sz)); szFilterSpecFromSz1Sz2(szMtkFilterSpec,sz,"*.MTK");
LoadStrIntoAnsiBuf(hInstance,IDS_RDFSPEC,sz,sizeof(sz)); szFilterSpecFromSz1Sz2(szRdfFilterSpec,sz,"*.RDF");
LoadStrIntoAnsiBuf(hInstance,IDS_MPJSPEC,sz,sizeof(sz)); szFilterSpecFromSz1Sz2(szMPJFilterSpec,sz,"*.MPJ"); szFilterSpecFromSz1Sz2(szFilterSpec,sz,"*.MPJ");
LoadStrIntoAnsiBuf(hInstance, IDS_OPENTITLE, szOpenDlgTitle, sizeof(szOpenDlgTitle)); LoadStrIntoAnsiBuf(hInstance, IDS_SAVETITLE, szSaveDlgTitle, sizeof(szSaveDlgTitle));
wc.style = 0; wc.lpfnWndProc = StatusWndProc; wc.cbClsExtra = 0; wc.cbWndExtra = 0; wc.hInstance = hInstance; wc.hIcon = LoadIcon((HINSTANCE) NULL, IDI_APPLICATION); wc.hCursor = LoadCursor((HINSTANCE) NULL, IDC_ARROW); wc.hbrBackground = (HBRUSH)GetStockObject(LTGRAY_BRUSH); wc.lpszMenuName = NULL; wc.lpszClassName = szStatusClass;
if (! RegisterClass( (CONST WNDCLASS *)&wc)) { return (FALSE); }
wc.style = 0; wc.lpfnWndProc = MainWndProc; wc.cbClsExtra = 0; wc.cbWndExtra = 0; wc.hInstance = hInstance; wc.hIcon = LoadIcon(hInstance,TEXT("RLAdminIcon")); wc.hCursor = LoadCursor((HINSTANCE) NULL, IDC_ARROW); wc.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH); wc.lpszMenuName = TEXT("RLAdmin"); wc.lpszClassName = szClassName;
return( RegisterClass( (CONST WNDCLASS *)&wc) ? TRUE : FALSE); }
/**
* * * Function: InitInstance * Creates the main, and status windows for the program. * The status window is sized according to the main window * size. InitInstance also loads the acclerator table, and prepares * the global openfilename structure for later use. * * * Errors Codes: * TRUE, windows created correctly. * FALSE, error on create windows calls. * * History: * 9/11, Implemented TerryRu * * **/
BOOL InitInstance(HINSTANCE hInstance, int nCmdShow) { RECT Rect;
hAccTable = LoadAccelerators(hInst, TEXT("RLAdmin"));
hMainWnd = CreateWindow( szClassName, tszAppName, WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, (HWND) NULL, (HMENU) NULL, (HINSTANCE)hInstance, (LPVOID) NULL);
if ( ! hMainWnd ) { return( FALSE); }
DragAcceptFiles(hMainWnd, TRUE);
GetClientRect(hMainWnd, (LPRECT) &Rect);
// Create a child list box window
hListWnd = CreateWindow( TEXT("LISTBOX"), NULL, WS_CHILD | LBS_WANTKEYBOARDINPUT | LBS_NOTIFY | LBS_NOINTEGRALHEIGHT | LBS_OWNERDRAWFIXED | WS_VSCROLL | WS_HSCROLL | WS_BORDER , 0, 0, (Rect.right-Rect.left), (Rect.bottom-Rect.top), hMainWnd, (HMENU)IDC_LIST, // Child control i.d.
hInstance, NULL);
if ( ! hListWnd ) { DeleteObject((HGDIOBJ)hMainWnd); return( FALSE); }
// Creat a child status window
hStatusWnd = CreateWindow( szStatusClass, NULL, WS_CHILD | WS_BORDER | WS_VISIBLE, 0, 0, 0, 0, hMainWnd, NULL, hInst, NULL);
if ( ! hStatusWnd ) { // clean up after errors.
DeleteObject((HGDIOBJ)hListWnd); DeleteObject((HGDIOBJ)hMainWnd); return( FALSE); }
hHourGlass = LoadCursor( (HINSTANCE) NULL, IDC_WAIT);
// Fill in non-variant fields of OPENFILENAMEA struct.
ofn.lStructSize = sizeof( OPENFILENAMEA); ofn.hwndOwner = hMainWnd; ofn.lpstrFilter = szFilterSpec; ofn.lpstrCustomFilter = szCustFilterSpec; ofn.nMaxCustFilter = MAXCUSTFILTER; ofn.nFilterIndex = 1; ofn.lpstrFile = szFileName; ofn.nMaxFile = MAXFILENAME; ofn.lpstrInitialDir = NULL; ofn.lpstrFileTitle = szFileTitle; ofn.nMaxFileTitle = MAXFILENAME; ofn.lpstrTitle = NULL; ofn.lpstrDefExt = "MPJ"; ofn.Flags = 0;
GetLangList();
ShowWindow(hMainWnd, nCmdShow); UpdateWindow(hMainWnd);
return TRUE; }
/**
* * * Function: WinMain * Calls the intialization functions, to register, and create the * application windows. Once the windows are created, the program * enters the GetMessage loop. * * * Arguements: * hInstace, handle for this instance * hPrevInstanc, handle for possible previous instances * lpszCmdLine, long pointer to exec command line. * nCmdShow, code for main window display. * * * Errors Codes: * IDS_ERR_REGISTER_CLASS, error on windows register * IDS_ERR_CREATE_WINDOW, error on create windows * otherwise, status of last command. * * History: * * **/
INT WINAPI WinMain(
HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpszCmdLine, int nCmdShow) { MSG msg; HWND FirstWnd = NULL; HWND FirstChildWnd = NULL; static TCHAR szString[256] = TEXT("");
hInst = hInstance; bRLGui = TRUE;
if ( FirstWnd = FindWindow( szClassName,NULL) ) { // checking for previous instance
FirstChildWnd = GetLastActivePopup( FirstWnd); BringWindowToTop( FirstWnd); ShowWindow( FirstWnd, SW_SHOWNORMAL);
if ( FirstWnd != FirstChildWnd ) { BringWindowToTop( FirstChildWnd); } return( FALSE); }
GetModuleFileNameA( hInst, szDHW, DHWSIZE); GetInternalName( szDHW, szAppName, ACHARSIN( sizeof( szAppName))); szFileName[0] = '\0'; lFilePointer[0] = (LONG)-1;
#ifdef UNICODE
_MBSTOWCS( tszAppName, szAppName, WCHARSIN( sizeof( tszAppName)), ACHARSIN( strlen( szAppName) + 1)); #else
strcpy( tszAppName, szAppName); #endif
// register window classes if first instance of application
if ( ! hPrevInstance ) { if ( ! InitApplication( hInstance) ) { /* Registering one of the windows failed */ LoadString( hInst, IDS_ERR_REGISTER_CLASS, szString, TCHARSIN( sizeof( szString))); MessageBox( NULL, szString, NULL, MB_ICONEXCLAMATION); return( IDS_ERR_REGISTER_CLASS); } }
// Create windows for this instance of application
if ( ! InitInstance( hInstance, nCmdShow) ) { LoadString( hInst, IDS_ERR_CREATE_WINDOW, szString, TCHARSIN( sizeof( szString))); MessageBox( NULL, szString, NULL, MB_ICONEXCLAMATION); return( IDS_ERR_CREATE_WINDOW); }
// Main Message Loop
while ( GetMessage( &msg, (HWND)NULL, 0, 0) ) { if ( hTokEditDlgWnd ) { if ( IsDialogMessage( hTokEditDlgWnd, &msg) ) { continue; } }
if ( TranslateAccelerator( hMainWnd, hAccTable, &msg) ) { continue; }
TranslateMessage( (CONST MSG *)&msg); DispatchMessage( (CONST MSG *)&msg); } return( (INT)msg.wParam); }
/**
* * * Function: MainWndProc * Process the windows messages for the main window of the application. * All user inputs go through this window procedure. * See cases in the switch table for a description of each message type. * * * Arguments: * * Returns: * * Errors Codes: * * History: * * **/
INT_PTR APIENTRY MainWndProc(
HWND hWnd, UINT wMsg, WPARAM wParam, LPARAM lParam) { DoListBoxCommand (hWnd, wMsg, wParam, lParam);
switch (wMsg) { case WM_DROPFILES: { #ifndef CAIRO
DragQueryFileA((HDROP)wParam, 0, szDHW, MAXFILENAME); #else
DragQueryFile((HDROP)wParam, 0, szDHW, MAXFILENAME); #endif
MessageBoxA( hWnd, szDHW, szAppName, MB_OK);
if ( SendMessage( hWnd, WM_SAVEPROJECT, (WPARAM)0, (LPARAM)0) ) { if ( GetMasterProjectData( gProj.szMpj, NULL, NULL, FALSE) == SUCCESS ) { sprintf( szDHW, "%s - %s", szAppName, gProj.szMpj); SetWindowTextA( hMainWnd, szDHW); SendMessage( hMainWnd, WM_LOADTOKENS, (WPARAM)0, (LPARAM)0); } } DragFinish((HDROP)wParam); return( TRUE); }
case WM_COMMAND:
if ( DoMenuCommand( hWnd, wMsg, wParam, lParam) ) { return( TRUE); } break;
case WM_CLOSE:
SendMessage( hWnd, WM_SAVEPROJECT, (WPARAM)0, (LPARAM)0); DestroyWindow( hMainWnd); DestroyWindow( hListWnd); DestroyWindow( hStatusWnd); _fcloseall(); FreeLangList();
#ifdef _DEBUG
{ FILE *pLeakList = fopen( "C:\\LEAKLIST.TXT", "wt"); FreeMemList( pLeakList); fclose( pLeakList); } #endif // _DEBUG
break;
case WM_CREATE: { HDC hdc; int cyBorder; TEXTMETRIC tm;
hdc = GetDC (hWnd); GetTextMetrics(hdc, &tm); ReleaseDC(hWnd, hdc);
cyBorder = GetSystemMetrics(SM_CYBORDER);
cyChildHeight = tm.tmHeight + 6 + cyBorder * 2; break; }
case WM_DESTROY:
WinHelpA( hWnd, gszHelpFile, HELP_QUIT, 0L); DragAcceptFiles( hMainWnd, FALSE); PostQuitMessage( 0); break;
case WM_INITMENU: // Enable or Disable the Paste menu item
// based on available Clipboard Text data
if ( wParam == (WPARAM)GetMenu( hMainWnd) ) { if ( OpenClipboard( hWnd)) { #if defined(UNICODE)
if ((IsClipboardFormatAvailable(CF_UNICODETEXT) || IsClipboardFormatAvailable(CF_OEMTEXT)) && fMtkFile) #else // not UNICODE
if ((IsClipboardFormatAvailable(CF_TEXT) || IsClipboardFormatAvailable(CF_OEMTEXT)) && fMtkFile) #endif // UNICODE
{ EnableMenuItem((HMENU) wParam, IDM_E_PASTE, MF_ENABLED); } else { EnableMenuItem((HMENU) wParam, IDM_E_PASTE, MF_GRAYED); }
CloseClipboard(); return (TRUE); } } break;
case WM_QUERYENDSESSION: /* message: to end the session? */ if ( SendMessage( hWnd, WM_SAVEPROJECT, (WPARAM)0, (LPARAM)0) ) { return TRUE; } else { return FALSE; }
case WM_SETFOCUS: SetFocus (hListWnd); break;
case WM_DRAWITEM: DrawLBItem((LPDRAWITEMSTRUCT) lParam); break;
case WM_DELETEITEM: GlobalFree((HGLOBAL) ((LPDELETEITEMSTRUCT) lParam)->itemData); break;
case WM_SIZE: { int cxWidth; int cyHeight; int xChild; int yChild;
cxWidth = LOWORD(lParam); cyHeight = HIWORD(lParam);
xChild = 0; yChild = cyHeight - cyChildHeight + 1;
MoveWindow(hListWnd, 0, 0, cxWidth, yChild , TRUE); MoveWindow(hStatusWnd, xChild, yChild, cxWidth, cyChildHeight, TRUE); break; }
case WM_LOADTOKENS: { HMENU hMenu = NULL; FILE *f = NULL; OFSTRUCT Of = { 0, 0, 0, 0, 0, ""};
// Remove the current token list
SendMessage( hListWnd, LB_RESETCONTENT, (WPARAM)0, (LPARAM)0); CleanDeltaList();
// Hide token list, while we add new tokens
ShowWindow(hListWnd, SW_HIDE);
if ( OpenFile( gMstr.szMtk, &Of, OF_EXIST) == HFILE_ERROR ) { // file doesn't exist, create it
BOOL bUpdate; HCURSOR hOldCursor;
hOldCursor = SetCursor(hHourGlass); LoadCustResDescriptions(gMstr.szRdfs);
GenerateTokFile(gMstr.szMtk, gMstr.szSrc, &bUpdate, 0); SetCursor(hOldCursor); ClearResourceDescriptions(); SzDateFromFileName( gMstr.szSrcDate, gMstr.szSrc); SzDateFromFileName( gMstr.szMpjLastRealUpdate, gMstr.szMtk); fMpjChanges = TRUE; fMPJOutOfDate = FALSE; }
SzDateFromFileName( szDHW, gMstr.szSrc);
if ( lstrcmpA( szDHW, gMstr.szSrcDate) ) { HCURSOR hOldCursor; BOOL bUpdate;
// MPJ is not up to date
fMPJOutOfDate = TRUE; hOldCursor = SetCursor( hHourGlass); LoadCustResDescriptions( gMstr.szRdfs); GenerateTokFile( gMstr.szMtk, gMstr.szSrc, &bUpdate, 0); if ( bUpdate ) { SzDateFromFileName( gMstr.szMpjLastRealUpdate, gMstr.szMtk); }
ClearResourceDescriptions(); SzDateFromFileName(gMstr.szSrcDate, gMstr.szSrc); fMpjChanges = TRUE; fMPJOutOfDate = FALSE; SetCursor(hOldCursor); } else { fMPJOutOfDate = FALSE; }
if ( f = fopen(gMstr.szMtk,"rt") ) { HCURSOR hOldCursor;
hOldCursor = SetCursor(hHourGlass);
// Insert tokens from token file into the list box
pTokenDeltaInfo = InsertMtkList(f); FCLOSE(f);
// Make list box visible
ShowWindow(hListWnd, SW_SHOW);
hMenu=GetMenu(hWnd); EnableMenuItem(hMenu, IDM_P_CLOSE, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_P_VIEW, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_E_FIND, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_E_FINDUP, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_E_FINDDOWN, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_E_REVIEW, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_E_COPY, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_E_COPYTOKEN, MF_ENABLED|MF_BYCOMMAND); EnableMenuItem(hMenu, IDM_E_PASTE, MF_ENABLED|MF_BYCOMMAND); fMtkFile = TRUE; fMtkChanges = FALSE;
SetCursor(hOldCursor); } break; }
case WM_SAVEPROJECT: { fMtkFile = FALSE;
if ( fMtkChanges ) { FILE *f = NULL;
if ( (f = fopen( gMstr.szMtk, "wt")) ) { SaveMtkList( hWnd,f); FCLOSE(f); SzDateFromFileName( gMstr.szMpjLastRealUpdate, gMstr.szMtk); fMtkChanges = FALSE; fMpjChanges = TRUE; } else { LoadStrIntoAnsiBuf(hInst, IDS_FILESAVEERR, szDHW, DHWSIZE); MessageBoxA( hWnd, szDHW, gMstr.szMtk, MB_ICONHAND | MB_OK); return FALSE; } }
if ( fMpjChanges ) { if ( PutMasterProjectData( gProj.szMpj) != SUCCESS ) { LoadStrIntoAnsiBuf(hInst, IDS_FILESAVEERR, szDHW, DHWSIZE); MessageBoxA(hWnd, szDHW,gProj.szMpj, MB_ICONHAND | MB_OK); return FALSE; } fMpjChanges = FALSE; } return TRUE; // everything saved ok
} default: break; } return (DefWindowProc(hWnd, wMsg, wParam, lParam)); }
/**
* * * Function: DoListBoxCommand * Processes the messages sent to the list box. If the message is * not reconized as a list box message, it is ignored and not processed. * As the user scrolls through the tokens WM_UPDSTATLINE messages are * sent to the status window to indicate the current selected token. * The list box goes into Edit Mode by pressing the enter key, or * by double clicking on the list box. After the edit is done, a WM_TOKEDIT * message is sent back to the list box to update the token. The * list box uses control ID IDC_LIST. * * * * Arguments: * wMsg List Box message ID * wParam Either IDC_LIST, or VK_RETURN depending on wMsg * lParam LPTSTR to selected token during WM_TOKEDIT message. * * Returns: * * * Errors Codes: * TRUE. Message processed. * FALSE. Message not processed. * * History: * 01/92 Implemented. TerryRu. * 01/92 Fixed problem with DblClick, and Enter processing. TerryRu. * * **/
INT_PTR DoListBoxCommand(HWND hWnd, UINT wMsg, WPARAM wParam, LPARAM lParam) { TOKEN tok; // struct for token read from token list
TCHAR szName[32] = TEXT(""); // buffer to hold token name
CHAR szTmpBuf[64] = ""; TCHAR szID[14] = TEXT(""); // buffer to hold token id
TCHAR sz[512] = TEXT(""); // buffer to hold messages
static UINT wIndex= 0; LONG lListParam = 0L; HWND hCtl = NULL; LPTSTR lpstrToken = NULL; HGLOBAL hMem = NULL;
// this is the WM_COMMAND
switch (wMsg) { case WM_TOKEDIT: { WORD wReservedOld; TCHAR *szBuffer;
// Message sent by TokEditDlgProc to
// indicate change in the token text.
// Response to the message by inserting
// new token text into list box
// Insert the selected token into token struct
hMem = (HGLOBAL)SendMessage( hListWnd, LB_GETITEMDATA, (WPARAM)wIndex, (LPARAM)0); lpstrToken = (LPTSTR)GlobalLock( hMem); szBuffer = (TCHAR *)FALLOC( MEMSIZE( lstrlen( lpstrToken) + 1)); lstrcpy( szBuffer, lpstrToken); GlobalUnlock( hMem); ParseBufToTok(szBuffer, &tok); RLFREE( szBuffer);
wReservedOld = tok.wReserved;
switch (LOWORD(wParam)) { case 0: tok.wReserved = 0; break;
case 1: tok.wReserved = ST_CHANGED|ST_NEW; break;
case 2: tok.wReserved = ST_NEW; break;
case 3: tok.wReserved = ST_READONLY; break; }
if (wReservedOld != tok.wReserved) { fMtkChanges = TRUE; } szBuffer = (TCHAR *)FALLOC( MEMSIZE( TokenToTextSize( &tok))); ParseTokToBuf( szBuffer, &tok); RLFREE( tok.szText);
SendMessage( hListWnd, WM_SETREDRAW, (WPARAM)FALSE, (LPARAM)0);
// Now remove old token
SendMessage( hListWnd, LB_DELETESTRING, (WPARAM)wIndex, (LPARAM)0);
// Replacing with the new token
hMem = GlobalAlloc( GMEM_ZEROINIT, MEMSIZE( lstrlen( szBuffer) + 1)); lpstrToken = (LPTSTR)GlobalLock( hMem); lstrcpy( lpstrToken, szBuffer); GlobalUnlock( hMem); SendMessage( hListWnd, LB_INSERTSTRING, (WPARAM)wIndex, (LPARAM)hMem); RLFREE( szBuffer);
// Now put focus back on the current string
SendMessage( hListWnd, LB_SETCURSEL, (WPARAM)wIndex, (LPARAM)0); SendMessage( hListWnd, WM_SETREDRAW, (WPARAM)TRUE, (LPARAM)0); InvalidateRect( hListWnd, NULL, TRUE);
return TRUE; } case WM_CHARTOITEM: case WM_VKEYTOITEM: { #ifdef RLWIN16
LONG lListParam = 0; #endif
UINT wListParam = 0;
// Messages sent to list box when keys are depressed.
// Check for Return key pressed.
switch(GET_WM_COMMAND_ID(wParam, lParam)) { case VK_RETURN: #ifdef RLWIN16
lListParam = (LONG) MAKELONG(NULL, LBN_DBLCLK); SendMessage( hMainWnd, WM_COMMAND, (WPARAM)IDC_LIST, (LPARAM)lListParam); #else
SendMessage( hMainWnd, WM_COMMAND, MAKEWPARAM( IDC_LIST, LBN_DBLCLK), (LPARAM)0); #endif
default: break; } break; } case WM_COMMAND: switch (GET_WM_COMMAND_ID(wParam, lParam)) { case IDC_LIST: /*
* * This is where we process the list box messages. * The TokEditDlgProc is used to * edit the token selected in LBS_DBLCLK message * */ switch (GET_WM_COMMAND_CMD(wParam, lParam)) { case (UINT) LBN_ERRSPACE: LoadString( hInst, IDS_ERR_NO_MEMORY, sz, TCHARSIN( sizeof( sz))); MessageBox ( hWnd, sz, tszAppName, MB_ICONHAND | MB_OK); return TRUE;
case LBN_DBLCLK: { TCHAR szResIDStr[20] = TEXT(""); LPTSTR lpstrToken; TCHAR *szBuffer;
wIndex = (UINT)SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0); if (wIndex == (UINT) -1) { return TRUE; }
// double click, or Return entered, go into token edit mode.
if (!hTokEditDlgWnd) { // set up modaless dialog box to edit token
#ifdef RLWIN32
hTokEditDlgWnd = CreateDialog(hInst, TEXT("RLAdmin"), hWnd, TokEditDlgProc); #else
lpTokEditDlg = (FARPROC) MakeProcInstance(TokEditDlgProc, hInst); hTokEditDlgWnd = CreateDialog(hInst, TEXT("RLAdmin"), hWnd, lpTokEditDlg); #endif
}
// Get token info from listbox, and place in token struct
hMem = (HGLOBAL)SendMessage( hListWnd, LB_GETITEMDATA, (WPARAM)wIndex, (LPARAM)0); lpstrToken = (LPTSTR)GlobalLock( hMem); szBuffer = (LPTSTR)FALLOC( MEMSIZE( lstrlen( lpstrToken) + 1)); lstrcpy( szBuffer, lpstrToken); GlobalUnlock( hMem); ParseBufToTok(szBuffer, &tok); RLFREE( szBuffer);
// Now get the token name
// Its either a string, or ordinal number
if (tok.szName[0]) { lstrcpy(szName, tok.szName); } else { #ifdef UNICODE
_itoa( tok.wName, szTmpBuf, 10); _MBSTOWCS( szName, szTmpBuf, WCHARSIN( sizeof( szName)), ACHARSIN( strlen( szTmpBuf) + 1)); #else
_itoa(tok.wName, szName, 10); #endif
} // Now get the token id
#ifdef UNICODE
_itoa( tok.wID, szTmpBuf, 10); _MBSTOWCS( szID, szTmpBuf, WCHARSIN( sizeof( szID)), ACHARSIN( strlen( szTmpBuf) + 1)); #else
_itoa( tok.wID, szID, 10); #endif
if ( tok.wType <= 16 || tok.wType == ID_RT_DLGINIT ) { LoadString( hInst, IDS_RESOURCENAMES+tok.wType, szResIDStr, TCHARSIN( sizeof( szResIDStr))); } else { #ifdef UNICODE
_itoa( tok.wType, szTmpBuf, 10); _MBSTOWCS( szResIDStr, szTmpBuf, WCHARSIN( sizeof( szResIDStr)), ACHARSIN( strlen( szTmpBuf) + 1)); #else
_itoa( tok.wType, szResIDStr, 10); #endif
}
// Now insert token info in TokEdit Dialog Box
SetDlgItemText(hTokEditDlgWnd, IDD_TOKTYPE, (LPTSTR) szResIDStr); SetDlgItemText(hTokEditDlgWnd, IDD_TOKNAME, (LPTSTR) szName); SetDlgItemText(hTokEditDlgWnd, IDD_TOKID, (LPTSTR) szID); SetDlgItemText(hTokEditDlgWnd, IDD_TOKCURTEXT, (LPTSTR) tok.szText); SetDlgItemText(hTokEditDlgWnd, IDD_TOKPREVTEXT, (LPTSTR) FindDeltaToken(tok, pTokenDeltaInfo, ST_CHANGED));
hCtl = GetDlgItem(hTokEditDlgWnd,IDD_STATUS); { int i;
if (tok.wReserved & ST_READONLY) { i = 3; } else if (tok.wReserved == ST_NEW) { i = 2; } else if (tok.wReserved & ST_CHANGED) { i = 1; } else { i = 0; } SendMessage( hCtl, CB_SETCURSEL, (WPARAM)i, (LPARAM)0); }
SetActiveWindow(hTokEditDlgWnd); wIndex = (UINT)SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0); RLFREE( tok.szText);
return TRUE; }
// let these messages fall through,
default: break; } default: return FALSE; }
break; // WM_COMMAND Case
} // Main List Box Switch
return FALSE; }
/**
* * * Function: DoMenuCommand. * Processes the Menu Command messages. * * Errors Codes: * TRUE. Message processed. * FALSE. Message not processed. * * History: * 01/92. Implemented. TerryRu. * * **/
INT_PTR DoMenuCommand(HWND hWnd, UINT wMsg, WPARAM wParam, LPARAM lParam) { static BOOL fListBox = FALSE; CHAR sz[256]=""; TCHAR tsz[256] = TEXT(""); #ifndef RLWIN32
FARPROC lpNewDlg,lpViewDlg; #endif
// Commands entered from the application menu, or child windows.
switch (GET_WM_COMMAND_ID(wParam, lParam)) {
case IDM_P_NEW:
if ( SendMessage( hWnd, WM_SAVEPROJECT, (WPARAM)0, (LPARAM)0) ) { CHAR szOldFile[MAXFILENAME] = "";
strcpy( szOldFile, szFileName);
if ( ! GetFileNameFromBrowse( hWnd, szFileName, MAXFILENAME, szSaveDlgTitle, szFilterSpec, "MPJ")) { break; } strcpy( gProj.szMpj, szFileName);
#ifdef RLWIN32
if (DialogBox(hInst, TEXT("PROJECT"), hWnd, NewDlgProc)) #else
lpNewDlg = MakeProcInstance( NewDlgProc, hInst);
if (DialogBox(hInst, TEXT("PROJECT"), hWnd, lpNewDlg)) #endif
{ sprintf( szDHW, "%s - %s", szAppName, gProj.szMpj); SetWindowTextA( hWnd,szDHW); gMstr.szSrcDate[0] = 0; gMstr.szMpjLastRealUpdate[0] = 0; SendMessage( hWnd, WM_LOADTOKENS, (WPARAM)0, (LPARAM)0); } else { strcpy( gProj.szMpj, szOldFile); } #ifndef RLWIN32
FreeProcInstance(lpTokEditDlg); #endif
} break;
case IDM_P_OPEN:
if ( SendMessage( hWnd, WM_SAVEPROJECT, (WPARAM)0, (LPARAM)0) ) { if ( GetFileNameFromBrowse( hWnd, gProj.szMpj, MAXFILENAME, szOpenDlgTitle, szFilterSpec, "MPJ")) { if ( GetMasterProjectData( gProj.szMpj, NULL, NULL, FALSE) == SUCCESS ) {
sprintf( szDHW, "%s - %s", szAppName, gProj.szMpj); SetWindowTextA( hMainWnd, szDHW); SendMessage( hMainWnd, WM_LOADTOKENS, (WPARAM)0, (LPARAM)0); } } } break;
case IDM_P_VIEW:
#ifdef RLWIN32
DialogBox(hInst, TEXT("VIEWPROJECT"), hWnd, ViewDlgProc); #else
lpViewDlg = MakeProcInstance(ViewDlgProc, hInst); DialogBox(hInst, TEXT("VIEWPROJECT"), hWnd, lpViewDlg); #endif
break;
case IDM_P_CLOSE: { HMENU hMenu;
hMenu = GetMenu(hWnd); if ( SendMessage( hWnd, WM_SAVEPROJECT, (WPARAM)0, (LPARAM)0) ) { // Remove file name from window title
SetWindowTextA(hMainWnd, szAppName);
// Hide token list since it's empty
ShowWindow(hListWnd, SW_HIDE);
// Remove the current token list
SendMessage( hListWnd, LB_RESETCONTENT, (WPARAM)0, (LPARAM)0); CleanDeltaList();
// Force Repaint of status Window
InvalidateRect(hStatusWnd, NULL, TRUE);
EnableMenuItem(hMenu,IDM_P_CLOSE,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_P_VIEW,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_E_FIND,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_E_FINDUP,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_E_FINDDOWN,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_E_REVIEW,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_E_COPY,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_E_COPYTOKEN,MF_GRAYED|MF_BYCOMMAND); EnableMenuItem(hMenu,IDM_E_PASTE,MF_GRAYED|MF_BYCOMMAND); } break; }
case IDM_P_EXIT: // send wm_close message to main window
PostMessage(hMainWnd, WM_CLOSE, (WPARAM)0, (LPARAM)0); break;
case IDM_E_COPYTOKEN: { HGLOBAL hStringMem = NULL; LPTSTR lpString = NULL; int nIndex = 0; int nLength = 0; LPTSTR lpstrToken = NULL;
// Is anything selected in the listbox
if ( (nIndex = (int)SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0)) != LB_ERR ) { HGLOBAL hMem = (HGLOBAL)SendMessage( hListWnd, LB_GETITEMDATA, (WPARAM)nIndex, (LPARAM)0); lpstrToken = (LPTSTR)GlobalLock( hMem); nLength = lstrlen( lpstrToken);
// Allocate memory for the string
if ( (hStringMem = GlobalAlloc(GHND, (DWORD) MEMSIZE(nLength+1))) != NULL ) { if ( (lpString = (LPTSTR)GlobalLock( hStringMem)) != NULL ) { // Get the selected text
lstrcpy( lpString, lpstrToken); GlobalUnlock( hMem); // Unlock the block
GlobalUnlock( hStringMem);
// Open the Clipboard and clear its contents
OpenClipboard( hWnd); EmptyClipboard();
// Give the Clipboard the text data
#if defined(UNICODE)
SetClipboardData(CF_UNICODETEXT, hStringMem); #else // not UNICODE
SetClipboardData( CF_TEXT, hStringMem); #endif // UNICODE
CloseClipboard();
hStringMem = NULL; } else { LoadString( hInst, IDS_ERR_NO_MEMORY, tsz, TCHARSIN( sizeof( tsz))); MessageBox( hWnd, tsz, tszAppName, MB_ICONHAND | MB_OK); } } else { LoadString( hInst, IDS_ERR_NO_MEMORY, tsz, TCHARSIN( sizeof(tsz))); MessageBox( hWnd, tsz, tszAppName, MB_ICONHAND | MB_OK); } } break; }
case IDM_E_COPY: { HGLOBAL hStringMem = NULL; HGLOBAL hMem = NULL; LPTSTR lpString = NULL; TCHAR *pszString = NULL; int nIndex = 0; int nLength = 0; int nActual = 0; TOKEN tok; LPTSTR lpstrToken = NULL;
// Is anything selected in the listbox
if ( (nIndex = (int)SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0)) != LB_ERR ) { hMem = (HGLOBAL)SendMessage( hListWnd, LB_GETITEMDATA, (WPARAM)nIndex, (LPARAM)0); lpstrToken = (LPTSTR) pszString = (TCHAR *)FALLOC( MEMSIZE( lstrlen( lpstrToken) + 1 )); lstrcpy( pszString, lpstrToken); GlobalUnlock( hMem); ParseBufToTok( pszString, &tok); RLFREE( pszString);
nLength = lstrlen(tok.szText);
// Allocate memory for the string
if ((hStringMem = GlobalAlloc(GHND, (DWORD)MEMSIZE( nLength + 1))) != NULL) { if ( (lpString = (LPTSTR)GlobalLock( hStringMem)) != NULL) { // Get the selected text
lstrcpy( lpString, tok.szText);
// Unlock the block
GlobalUnlock( hStringMem);
// Open the Clipboard and clear its contents
OpenClipboard(hWnd); EmptyClipboard();
// Give the Clipboard the text data
#if defined(UNICODE)
SetClipboardData(CF_UNICODETEXT, hStringMem); #else // not UNICODE
SetClipboardData(CF_TEXT, hStringMem); #endif // UNICODE
CloseClipboard();
hStringMem = NULL; } else { LoadString( hInst, IDS_ERR_NO_MEMORY, tsz, TCHARSIN( sizeof(tsz))); MessageBox( hWnd, tsz, tszAppName, MB_ICONHAND | MB_OK); } } else { LoadString( hInst, IDS_ERR_NO_MEMORY, tsz, TCHARSIN( sizeof( tsz))); MessageBox( hWnd, tsz, tszAppName, MB_ICONHAND | MB_OK); } RLFREE( tok.szText); } break; }
case IDM_E_PASTE: { HGLOBAL hClipMem = NULL; HGLOBAL hMem = NULL; LPTSTR lpClipMem = NULL; TCHAR *pszPasteString = NULL; int nIndex = 0; TOKEN tok; LPTSTR lpstrToken = NULL;
if (OpenClipboard(hWnd)) {
#if defined(UNICODE)
if(IsClipboardFormatAvailable(CF_UNICODETEXT) || IsClipboardFormatAvailable(CF_OEMTEXT)) #else // not UNICODE
if(IsClipboardFormatAvailable(CF_TEXT) || IsClipboardFormatAvailable(CF_OEMTEXT)) #endif // UNICODE
{ // Check for current position and change that token's text
nIndex = (int) SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0);
if (nIndex == LB_ERR) { #if defined(UNICODE) // if no select, just ignore it.
break; #else // not UNICODE
nIndex = -1; #endif // UNICODE
}
#if defined(UNICODE) //enabled Paste command
hClipMem = GetClipboardData(CF_UNICODETEXT); #else // not UNICODE
hClipMem = GetClipboardData(CF_TEXT); #endif // UNICODE
lpClipMem = (LPTSTR)GlobalLock( hClipMem); hMem = (HGLOBAL)SendMessage( hListWnd, LB_GETITEMDATA, (WPARAM)nIndex, (LPARAM)0); lpstrToken = (LPTSTR)GlobalLock( hMem); pszPasteString = (LPTSTR)FALLOC( MEMSIZE( lstrlen( lpstrToken) + 1)); lstrcpy( pszPasteString, lpstrToken); GlobalUnlock( hMem); // copy the string to the token
ParseBufToTok( pszPasteString, &tok); RLFREE( pszPasteString); RLFREE( tok.szText);
tok.szText = (TCHAR *)FALLOC( MEMSIZE( lstrlen( lpClipMem) + 1)); lstrcpy( tok.szText, lpClipMem);
GlobalUnlock(hClipMem); pszPasteString = (LPTSTR)FALLOC( MEMSIZE( TokenToTextSize( &tok) + 1)); ParseTokToBuf( pszPasteString, &tok); RLFREE( tok.szText);
// Paste the text
SendMessage( hListWnd, WM_SETREDRAW, (WPARAM)FALSE, (LPARAM)0);
SendMessage( hListWnd, LB_DELETESTRING, (WPARAM)nIndex, (LPARAM)0);
hMem = GlobalAlloc( GMEM_ZEROINIT, MEMSIZE( lstrlen( pszPasteString)+1)); lpstrToken = (LPTSTR)GlobalLock( hMem); lstrcpy( lpstrToken, pszPasteString); GlobalUnlock( hMem); SendMessage( hListWnd, LB_INSERTSTRING, (WPARAM)nIndex, (LPARAM)hMem); SendMessage( hListWnd, LB_SETCURSEL, (WPARAM)nIndex, (LPARAM)0); SendMessage( hListWnd, WM_SETREDRAW, (WPARAM)TRUE, (LPARAM)0); InvalidateRect(hListWnd,NULL,TRUE); fMtkChanges = TRUE; // Set Dirty Flag
RLFREE( pszPasteString);
// Close the Clipboard
CloseClipboard();
SetFocus(hListWnd); } } CloseClipboard(); break; }
case IDM_E_FINDDOWN:
if (fSearchStarted) { if ( ! DoTokenSearch( szSearchType, szSearchText, wSearchStatus, wSearchStatusMask, 0, TRUE) ) { TCHAR sz1[80], sz2[80];
LoadString( hInst, IDS_FIND_TOKEN, sz1, TCHARSIN( sizeof( sz1))); LoadString( hInst, IDS_TOKEN_NOT_FOUND, sz2, TCHARSIN( sizeof( sz2))); MessageBox( hWnd, sz2, sz1, MB_ICONINFORMATION | MB_OK); } break; } //... ELSE fall thru
case IDM_E_FINDUP:
if (fSearchStarted) { if ( ! DoTokenSearch( szSearchType, szSearchText, wSearchStatus, wSearchStatusMask, 1, TRUE) ) { TCHAR sz1[80], sz2[80]; LoadString( hInst, IDS_FIND_TOKEN, sz1, TCHARSIN( sizeof( sz1))); LoadString( hInst, IDS_TOKEN_NOT_FOUND, sz2, TCHARSIN( sizeof( sz2))); MessageBox( hWnd, sz2, sz1, MB_ICONINFORMATION | MB_OK); } break; } //... ELSE fall thru
case IDM_E_FIND: { #ifndef RLWIN32
FARPROC lpfnTOKFINDMsgProc;
lpfnTOKFINDMsgProc = MakeProcInstance((FARPROC)TOKFINDMsgProc, hInst);
if (!DialogBox( hInst, TEXT("TOKFIND"), hWnd, lpfnTOKFINDMsgProc)) #else
if (!DialogBox(hInst, TEXT("TOKFIND"), hWnd, TOKFINDMsgProc)) #endif
{ #ifndef DBCS
// 'Token Not Found' is strange because user selected cancel #3042
TCHAR sz1[80] = TEXT(""); TCHAR sz2[80] = TEXT("");
LoadString( hInst, IDS_FIND_TOKEN, sz1, TCHARSIN( sizeof( sz1))); LoadString( hInst, IDS_TOKEN_NOT_FOUND, sz2, TCHARSIN( sizeof( sz2))); MessageBox( hWnd, sz2, sz1, MB_ICONINFORMATION | MB_OK); #endif //DBCS
} #ifndef RLWIN32
FreeProcInstance( lpfnTOKFINDMsgProc); #endif
return TRUE; }
case IDM_E_REVIEW: { LRESULT lrSaveSelection = 0;
nUpdateMode = 1;
// set listbox selection to begining of the token list
lrSaveSelection = SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0);
SendMessage( hListWnd, LB_SETCURSEL, (WPARAM)0, (LPARAM)0);
if ( DoTokenSearch( NULL, NULL, ST_NEW, ST_NEW, FALSE, FALSE) ) { #ifdef RLWIN32
SendMessage( hMainWnd, WM_COMMAND, MAKEWPARAM( IDC_LIST, LBN_DBLCLK), (LPARAM)0); #else
SendMessage( hMainWnd, WM_COMMAND, IDC_LIST, MAKELONG( 0, LBN_DBLCLK)); #endif
} } break;
case IDM_H_CONTENTS: { OFSTRUCT Of = { 0, 0, 0, 0, 0, ""};
if ( OpenFile( gszHelpFile, &Of, OF_EXIST) == HFILE_ERROR) { LoadString( hInst, IDS_ERR_NO_HELP , tsz, TCHARSIN( sizeof( tsz))); MessageBox( hWnd, tsz, NULL, MB_OK); } else { WinHelpA( hWnd, gszHelpFile, HELP_KEY,(DWORD_PTR)((LPSTR)"RLAdmin")); } break; }
case IDM_H_ABOUT: { #ifndef RLWIN32
WNDPROC lpProcAbout;
lpProcAbout = MakeProcInstance(About, hInst); DialogBox(hInst, TEXT("ABOUT"), hWnd, lpProcAbout); FreeProcInstance(lpProcAbout); #else
DialogBox(hInst, TEXT("ABOUT"), hWnd, About); #endif
} break;
default: break; } // WM_COMMAND switch
return FALSE; }
/**
* * * Function: TokEditDlgProc * Procedure for the edit mode dialog window. Loads the selected token * info into the window, and allows the user to change the token text. * Once the edit is complete, the procedure sends a message to the * list box windows to update the current token info. * * * Arguments: * * Returns: NA. * * Errors Codes: * TRUE, carry out edit, and update token list box. * FALSE, cancel edit. * * History: * * **/
INT_PTR TokEditDlgProc(
HWND hDlg, UINT wMsg, WPARAM wParam, LPARAM lParam) { HWND hCtl; HWND hParentWnd; UINT static wcTokens = 0; UINT wIndex; static BOOL fChanged = FALSE;
switch(wMsg) { case WM_INITDIALOG: cwCenter(hDlg, 0); wcTokens = (UINT)SendMessage( hListWnd, LB_GETCOUNT, (WPARAM)0, (LPARAM)0); wcTokens--; hCtl = GetDlgItem(hDlg,IDD_STATUS); { TCHAR sz[80];
LoadString( hInst, IDS_UNCHANGED, sz, TCHARSIN( sizeof( sz))); SendMessage( hCtl, CB_ADDSTRING, (WPARAM)0, (LPARAM)sz);
LoadString( hInst, IDS_CHANGED, sz, TCHARSIN( sizeof( sz))); SendMessage( hCtl, CB_ADDSTRING, (WPARAM)0, (LPARAM)sz);
LoadString( hInst, IDS_NEW, sz, TCHARSIN( sizeof( sz))); SendMessage( hCtl, CB_ADDSTRING, (WPARAM)0, (LPARAM)sz);
LoadString( hInst, IDS_READONLY, sz, TCHARSIN( sizeof( sz))); SendMessage( hCtl, CB_ADDSTRING, (WPARAM)0, (LPARAM)sz); }
if( ! nUpdateMode ) {
if (hCtl = GetDlgItem(hDlg, IDD_SKIP)) { EnableWindow(hCtl, FALSE); } } else { if (hCtl = GetDlgItem(hDlg, IDD_SKIP)) { EnableWindow(hCtl, TRUE); } } fChanged = FALSE; return TRUE;
case WM_COMMAND: switch (GET_WM_COMMAND_ID(wParam, lParam)) { case IDD_SKIP: wIndex = (UINT)SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0);
if ( nUpdateMode && wIndex < wcTokens ) { wIndex ++; SendMessage( hListWnd, LB_SETCURSEL, (WPARAM)wIndex, (LPARAM)0);
if ( DoTokenSearch( NULL, NULL, ST_NEW, ST_NEW, FALSE, FALSE) ) { wIndex = (UINT)SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0); SendMessage( hMainWnd, WM_COMMAND, MAKEWPARAM( IDC_LIST, LBN_DBLCLK), (LPARAM)0); return TRUE; } } nUpdateMode = 0; DestroyWindow(hDlg); #ifndef RLWIN32
FreeProcInstance(lpTokEditDlg); #endif
hTokEditDlgWnd = 0; break;
case IDD_STATUS: fChanged = TRUE; break;
case IDOK: wIndex = (UINT)SendMessage( hListWnd, LB_GETCURSEL, (WPARAM)0, (LPARAM)0); if (fChanged) { int i; fChanged = FALSE;
hCtl = GetDlgItem(hDlg, IDD_STATUS); i = (int)SendMessage( hCtl, CB_GETCURSEL, (WPARAM)0, (LPARAM)0); hParentWnd = GetParent(hDlg); SendMessage( hParentWnd, WM_TOKEDIT, (WPARAM)i, (LPARAM)0); } // Exit, or goto to next changed token if in update mode
if ( nUpdateMode && wIndex < wcTokens ) { wIndex++; SendMessage( hListWnd, LB_SETCURSEL, (WPARAM)wIndex, (LPARAM)0);
if ( DoTokenSearch( NULL, NULL, ST_NEW, ST_NEW, FALSE, FALSE) ) { // go into edit mode
SendMessage( hMainWnd, WM_COMMAND, MAKEWPARAM( IDC_LIST, LBN_DBLCLK), (LPARAM)0);
return TRUE; } } // fall through to IDCANCEL
case IDCANCEL: nUpdateMode = 0; // remove edit dialog box
DestroyWindow(hDlg); #ifndef RLWIN32
FreeProcInstance(lpTokEditDlg); #endif
hTokEditDlgWnd = 0; break;
} // WM_COMMAND
return TRUE;
default: if (hCtl = GetDlgItem(hDlg, IDOK)) { EnableWindow(hCtl, TRUE); } return FALSE; } // Main Switch
}
/**
* * * Function: TOKFINDMsgProc * * Arguments: * * Returns: * NA. * * Errors Codes: * * History: * * **/
INT_PTR TOKFINDMsgProc(HWND hWndDlg, UINT wMsg, WPARAM wParam, LPARAM lParam) { HWND hCtl; int rgiTokenTypes[]= { ID_RT_MENU, ID_RT_DIALOG, ID_RT_STRING, ID_RT_ACCELERATORS, ID_RT_RCDATA, ID_RT_ERRTABLE, ID_RT_NAMETABLE, ID_RT_VERSION, ID_RT_DLGINIT };
TCHAR szTokenType[40] = TEXT(""); UINT i;
switch(wMsg) { case WM_INITDIALOG:
CheckDlgButton(hWndDlg, IDD_READONLY, 2); CheckDlgButton(hWndDlg, IDD_CHANGED, 2); CheckDlgButton(hWndDlg, IDD_FINDDOWN, 1); hCtl = GetDlgItem(hWndDlg, IDD_TYPELST);
for ( i = 0; i < sizeof( rgiTokenTypes) / 2; i++) { LoadString( hInst, IDS_RESOURCENAMES + rgiTokenTypes[i], szTokenType, TCHARSIN( sizeof( szTokenType))); SendMessage( hCtl, CB_ADDSTRING, (WPARAM)0, (LPARAM)szTokenType); } return TRUE; break;
case WM_COMMAND:
switch(wParam) { case IDOK: /* Button text: "Okay" */ fSearchStarted = TRUE; GetDlgItemText( hWndDlg, IDD_TYPELST, szSearchType, TCHARSIN( sizeof( szSearchType))); GetDlgItemText( hWndDlg, IDD_FINDTOK, szSearchText, TCHARSIN( sizeof( szSearchText)));
wSearchStatus = wSearchStatusMask = 0;
switch (IsDlgButtonChecked(hWndDlg, IDD_READONLY)) { case 1: wSearchStatus |= ST_READONLY;
case 0: wSearchStatusMask |= ST_READONLY; }
switch (IsDlgButtonChecked(hWndDlg, IDD_CHANGED)) { case 1: wSearchStatus |= ST_CHANGED;
case 0: wSearchStatusMask |= ST_CHANGED; }
fSearchDirection = IsDlgButtonChecked(hWndDlg, IDD_FINDUP);
if( DoTokenSearch(szSearchType, szSearchText, wSearchStatus, wSearchStatusMask, fSearchDirection, FALSE) ) { EndDialog( hWndDlg, TRUE ); } else { TCHAR sz1[80], sz2[80];
LoadString( hInst, IDS_FIND_TOKEN, sz1, TCHARSIN( sizeof( sz1))); LoadString( hInst, IDS_TOKEN_NOT_FOUND, sz2, TCHARSIN( sizeof( sz2))); MessageBox( hWndDlg, sz2, sz1, MB_ICONINFORMATION | MB_OK); EndDialog( hWndDlg, FALSE ); }
case IDCANCEL:
EndDialog( hWndDlg, FALSE); return TRUE; } break; /* End of WM_COMMAND */
default: return FALSE; } return FALSE; }
/**
* Function: NewDlgProc * Procedure for the new project dialog window. * * Arguments: * * Returns: NA. * * Errors Codes: * TRUE, carry out edit, and update token list box. * FALSE, cancel edit. * * History: **/
INT_PTR APIENTRY NewDlgProc(
HWND hDlg, UINT wMsg, WPARAM wParam, LPARAM lParam) { CHAR pszDrive[ _MAX_DRIVE] = ""; CHAR pszDir[ _MAX_DIR] = ""; CHAR pszName[ _MAX_FNAME] = ""; CHAR pszExt[ _MAX_EXT] = "";
switch ( wMsg ) { case WM_INITDIALOG: { LPTSTR pszLangName = NULL; OFSTRUCT Of = { 0, 0, 0, 0, 0, ""}; int nSel = 0;
iLastBox = IDD_SOURCERES; fLangSelected = FALSE; _splitpath( gProj.szMpj, pszDrive, pszDir, pszName, pszExt);
sprintf( szDHW, "%s%s%s.%s", pszDrive, pszDir, pszName, "EXE"); SetDlgItemTextA( hDlg, IDD_SOURCERES, szDHW);
sprintf( szDHW, "%s%s%s.%s", pszDrive, pszDir, pszName, "MTK"); SetDlgItemTextA( hDlg, IDD_MTK, szDHW);
sprintf( szDHW, "%s%s%s.%s", pszDrive, pszDir, pszName, "RDF");
if ( OpenFile( szDHW, &Of, OF_EXIST) != HFILE_ERROR ) SetDlgItemTextA( hDlg, IDD_RDFS, szDHW); else SetDlgItemText( hDlg, IDD_RDFS, TEXT(""));
if ( gMstr.uCodePage == CP_ACP ) gMstr.uCodePage = GetACP(); else if ( gMstr.uCodePage == CP_OEMCP ) gMstr.uCodePage = GetOEMCP();
if ( ! IsValidCodePage( gMstr.uCodePage) ) { static TCHAR szMsg[ 256]; CHAR *pszCP[1];
pszCP[0] = UlongToPtr(gMstr.uCodePage);
LoadString( hInst, IDS_NOCPXTABLE, szMsg, 256); FormatMessage( FORMAT_MESSAGE_FROM_STRING | FORMAT_MESSAGE_ARGUMENT_ARRAY, szMsg, 0, 0, (LPTSTR)szDHW, DHWSIZE/sizeof(TCHAR), (va_list *)pszCP); MessageBox( hDlg, (LPCTSTR)szDHW, tszAppName, MB_ICONHAND|MB_OK); SetDlgItemInt( hDlg, IDD_TOK_CP, gMstr.uCodePage, FALSE); return( TRUE); } SetDlgItemInt( hDlg, IDD_TOK_CP, gMstr.uCodePage, FALSE); PostMessage( hDlg, WM_COMMAND, IDD_BROWSE, 0); return TRUE; }
case WM_COMMAND:
switch ( GET_WM_COMMAND_ID( wParam, lParam) ) { case IDD_SOURCERES: case IDD_MTK: case IDD_RDFS: iLastBox = GET_WM_COMMAND_ID(wParam, lParam); break;
case IDD_BROWSE: switch ( iLastBox ) { case IDD_SOURCERES: szFSpec = szExeResFilterSpec; szExt = "EXE"; LoadStrIntoAnsiBuf( hInst, IDS_RES_SRC, szPrompt, ACHARSIN( sizeof( szPrompt))); fLangSelected = FALSE; break;
case IDD_RDFS: szFSpec = szRdfFilterSpec; szExt = "RDF"; LoadStrIntoAnsiBuf( hInst, IDS_RDF, szPrompt, ACHARSIN( sizeof( szPrompt))); break;
case IDD_MTK: szFSpec = szMtkFilterSpec; szExt = "MTK"; LoadStrIntoAnsiBuf( hInst, IDS_MTK, szPrompt, ACHARSIN( sizeof(szPrompt))); break; }
GetDlgItemTextA(hDlg, iLastBox, szNewFileName, MAXFILENAME);
if ( GetFileNameFromBrowse( hDlg, szNewFileName, MAXFILENAME, szPrompt, szFSpec, szExt) ) { SetDlgItemTextA( hDlg, iLastBox, szNewFileName);
if ( iLastBox == IDD_SOURCERES ) { // fill in suggested name for the MTK box
CHAR pszDrive[_MAX_DRIVE] = ""; CHAR pszDir[ _MAX_DIR] = ""; CHAR pszName[ _MAX_FNAME] = ""; CHAR pszExt[ _MAX_EXT] = "";
lstrcpyA( gMstr.szSrc, szNewFileName);
FillListAndSetLang( hDlg, IDD_MSTR_LANG_NAME, &gMstr.wLanguageID, &fLangSelected);
_splitpath( szNewFileName, pszDrive, pszDir, pszName, pszExt); GetDlgItemTextA(hDlg, IDD_MTK, szNewFileName, MAXFILENAME);
if ( ! szNewFileName[0] ) { sprintf( szNewFileName, "%s%s%s.%s", pszDrive, pszDir, pszName, "MTK"); SetDlgItemTextA( hDlg, IDD_MTK, szNewFileName); } } } break;
case IDD_MSTR_LANG_NAME:
if ( GET_WM_COMMAND_CMD( wParam, lParam) == CBN_SELENDOK ) { fLangSelected = TRUE; } break;
case IDOK:
if ( fLangSelected ) { MSTRDATA stProject = { "", "", "", "", "", MAKELANGID( LANG_ENGLISH, SUBLANG_ENGLISH_US), CP_ACP }; BOOL fTranslated = FALSE; UINT uCP = GetDlgItemInt( hDlg, IDD_TOK_CP, &fTranslated, FALSE);
//... Get the selected language name
//... then set the appropriate lang id vals
INT_PTR nSel = SendDlgItemMessage( hDlg, IDD_MSTR_LANG_NAME, CB_GETCURSEL, (WPARAM)0, (LPARAM)0);
if ( nSel != CB_ERR && SendDlgItemMessage( hDlg, IDD_MSTR_LANG_NAME, CB_GETLBTEXT, (WPARAM)nSel, (LPARAM)(LPTSTR)szDHW) != CB_ERR ) { WORD wPri = 0; WORD wSub = 0;
if ( GetLangIDs( (LPTSTR)szDHW, &wPri, &wSub) ) { gMstr.wLanguageID = MAKELANGID( wPri, wSub); } else { fLangSelected = FALSE; return( TRUE); } }
if ( uCP == CP_ACP ) uCP = GetACP(); else if ( uCP == CP_OEMCP ) uCP = GetOEMCP();
if ( IsValidCodePage( uCP) ) { gMstr.uCodePage = uCP; } else { static TCHAR szMsg[ 256]; CHAR *pszCP[1];
pszCP[0] = UlongToPtr(uCP);
LoadString( hInst, IDS_NOCPXTABLE, szMsg, 256); FormatMessage( FORMAT_MESSAGE_FROM_STRING | FORMAT_MESSAGE_ARGUMENT_ARRAY, szMsg, 0, 0, (LPTSTR)szDHW, DHWSIZE/sizeof(TCHAR), (va_list *)pszCP); MessageBox( hDlg, (LPCTSTR)szDHW, tszAppName, MB_ICONHAND|MB_OK); SetDlgItemInt( hDlg, IDD_TOK_CP, gMstr.uCodePage, FALSE); return( TRUE); }
GetDlgItemTextA( hDlg, IDD_SOURCERES, stProject.szSrc, MAXFILENAME);
GetDlgItemTextA( hDlg, IDD_RDFS, stProject.szRdfs, MAXFILENAME);
GetDlgItemTextA( hDlg, IDD_MTK, stProject.szMtk, MAXFILENAME);
if ( stProject.szSrc[0] && stProject.szMtk[0] ) { _fullpath( gMstr.szSrc, stProject.szSrc, ACHARSIN( sizeof( gMstr.szSrc)));
_fullpath( gMstr.szMtk, stProject.szMtk, ACHARSIN( sizeof( gMstr.szMtk)));
if ( stProject.szRdfs[0] ) { _fullpath( gMstr.szRdfs, stProject.szRdfs, ACHARSIN( sizeof( gMstr.szRdfs))); } else { gMstr.szRdfs[0] = '\0'; } gProj.fSourceEXE = IsExe( gMstr.szSrc);
EndDialog( hDlg, TRUE); return( TRUE); } else { break; } } else { LoadString( hInst, IDS_SELECTLANG, (LPTSTR)szDHW, TCHARSIN( DHWSIZE)); MessageBox( hDlg, (LPTSTR)szDHW, tszAppName, MB_ICONHAND | MB_OK); break; }
case IDCANCEL: EndDialog(hDlg, FALSE); return( TRUE); } break; } return( FALSE); }
/**
* * * Function: ViewDlgProc * Procedure for the View project dialog window. * * Arguments: * * Returns: NA. * * Errors Codes: * TRUE, carry out edit, and update token list box. * FALSE, cancel edit. * * History: * * **/
INT_PTR ViewDlgProc(
HWND hDlg, UINT wMsg, WPARAM wParam, LPARAM lParam) { static int iLastBox = IDD_SOURCERES;
switch(wMsg) { case WM_INITDIALOG: { WORD wPri = PRIMARYLANGID( gMstr.wLanguageID); WORD wSub = SUBLANGID( gMstr.wLanguageID); LPTSTR pszName = GetLangName( wPri, wSub);
SetDlgItemTextA( hDlg, IDD_VIEW_SOURCERES, gMstr.szSrc); SetDlgItemTextA( hDlg, IDD_VIEW_MTK, gMstr.szMtk); SetDlgItemTextA( hDlg, IDD_VIEW_RDFS, gMstr.szRdfs); SetDlgItemText( hDlg, IDD_MSTR_LANG_NAME, pszName); SetDlgItemInt( hDlg, IDD_TOK_CP, gMstr.uCodePage, FALSE); return TRUE; }
case WM_COMMAND:
switch ( wParam ) { case IDOK: EndDialog( hDlg, TRUE); return TRUE; } } return FALSE; }
void DrawLBItem(LPDRAWITEMSTRUCT lpdis) { LPRECT lprc = (LPRECT) &(lpdis->rcItem); DWORD rgbOldText = 0; DWORD rgbOldBack = 0; HBRUSH hBrush; static DWORD rgbHighlightText; static DWORD rgbHighlightBack; static HBRUSH hBrushHilite = NULL; static HBRUSH hBrushNormal = NULL; static DWORD rgbChangedText; static DWORD rgbBackColor; static DWORD rgbUnchangedText; static DWORD rgbReadOnlyText; static DWORD rgbNewText; TCHAR *szToken = NULL; TOKEN tok; LPTSTR lpstrToken = NULL;
if (lpdis->itemAction & ODA_FOCUS) { DrawFocusRect(lpdis->hDC, (CONST RECT *)lprc); } else { HANDLE hMem = (HANDLE)SendMessage( lpdis->hwndItem, LB_GETITEMDATA, (WPARAM)lpdis->itemID, (LPARAM)0); lpstrToken = (LPTSTR)GlobalLock( hMem); szToken = (LPTSTR)FALLOC( MEMSIZE( lstrlen( lpstrToken) + 1)); lstrcpy( szToken, lpstrToken); GlobalUnlock( hMem); ParseBufToTok(szToken, &tok); RLFREE( szToken);
if (lpdis->itemState & ODS_SELECTED) { if (!hBrushHilite) { rgbHighlightText = GetSysColor(COLOR_HIGHLIGHTTEXT); rgbHighlightBack = GetSysColor(COLOR_HIGHLIGHT); hBrushHilite = CreateSolidBrush(rgbHighlightBack); } MakeStatusLine(&tok);
rgbOldText = SetTextColor(lpdis->hDC, rgbHighlightText); rgbOldBack = SetBkColor(lpdis->hDC, rgbHighlightBack);
hBrush = hBrushHilite; } else { if (!hBrushNormal) { rgbChangedText = RGB(255, 0, 0); rgbBackColor = RGB(192, 192, 192); rgbUnchangedText = RGB(0, 0, 0); rgbReadOnlyText = RGB(127, 127, 127); rgbNewText = RGB(0, 0, 255); hBrushNormal = CreateSolidBrush(rgbBackColor); } if (tok.wReserved & ST_READONLY) { rgbOldText = SetTextColor(lpdis->hDC, rgbReadOnlyText); } else if (tok.wReserved & ST_CHANGED) { rgbOldText = SetTextColor(lpdis->hDC, rgbChangedText); } else if (tok.wReserved & ST_NEW) { rgbOldText = SetTextColor(lpdis->hDC, rgbNewText); } else { rgbOldText = SetTextColor(lpdis->hDC, rgbUnchangedText); } rgbOldBack = SetBkColor(lpdis->hDC, rgbBackColor); hBrush = hBrushNormal; } FillRect(lpdis->hDC, (CONST RECT *)lprc, hBrush);
DrawText(lpdis->hDC, tok.szText, STRINGSIZE(lstrlen(tok.szText)), lprc, DT_LEFT|DT_NOPREFIX); RLFREE( tok.szText);
if (rgbOldText) { SetTextColor(lpdis->hDC, rgbOldText); }
if (rgbOldBack) { SetBkColor(lpdis->hDC, rgbOldBack); }
if (lpdis->itemState & ODS_FOCUS) { DrawFocusRect(lpdis->hDC, (CONST RECT *)lprc); } } }
/*
* Function: Make Status Line * Builds status line string from a token * * Inputs: * pszStatusLine, buffer to hold string * pTok, pointer to token structure * * History: * 2/92, implemented SteveBl * 7/92, changed to talk to new StatusWndProc t-GregTi */ static void MakeStatusLine(TOKEN *pTok) { static BOOL fFirstCall = TRUE; TCHAR szName[32] = TEXT(""); TCHAR szStatus[20] = TEXT(""); TCHAR szResIDStr[20] = TEXT("");
CHAR szTmpBuf[32] = "";
// now build status line
if (pTok->szName[0]) { lstrcpy(szName, pTok->szName); } else { #ifdef UNICODE
_itoa(pTok->wName, szTmpBuf, 10); _MBSTOWCS( szName, szTmpBuf, WCHARSIN( sizeof( szName)), ACHARSIN( strlen( szTmpBuf) + 1)); #else
_itoa(pTok->wName, szName, 10); #endif
}
if ( pTok->wReserved & ST_READONLY ) { LoadString( hInst, IDS_READONLY, szStatus, TCHARSIN( sizeof( szStatus))); } else if (pTok->wReserved == ST_NEW) { LoadString( hInst, IDS_NEW, szStatus, TCHARSIN( sizeof( szStatus))); } else if (pTok->wReserved & ST_CHANGED) { LoadString( hInst, IDS_CHANGED, szStatus, TCHARSIN( sizeof( szStatus))); } else { LoadString( hInst, IDS_UNCHANGED, szStatus, TCHARSIN( sizeof( szStatus))); }
if ( pTok->wType <= 16 || pTok->wType == ID_RT_DLGINIT ) { LoadString( hInst, IDS_RESOURCENAMES+pTok->wType, szResIDStr, TCHARSIN( sizeof( szResIDStr))); } else { #ifdef UNICODE
_itoa( pTok->wType, szTmpBuf, 10); _MBSTOWCS( szResIDStr, szTmpBuf, WCHARSIN( sizeof( szResIDStr)), ACHARSIN( strlen( szTmpBuf) + 1)); #else
_itoa(pTok->wType, szResIDStr, 10); #endif
}
if (fFirstCall) { SendMessage( hStatusWnd, WM_FMTSTATLINE, (WPARAM)0, (LPARAM)TEXT("10s10s5i8s4i")); fFirstCall = FALSE; } SendMessage( hStatusWnd, WM_UPDSTATLINE, (WPARAM)0, (LPARAM)szResIDStr); SendMessage( hStatusWnd, WM_UPDSTATLINE, (WPARAM)1, (LPARAM)szName); SendMessage( hStatusWnd, WM_UPDSTATLINE, (WPARAM)2, (LPARAM)pTok->wID); SendMessage( hStatusWnd, WM_UPDSTATLINE, (WPARAM)3, (LPARAM)szStatus); SendMessage( hStatusWnd, WM_UPDSTATLINE, (WPARAM)4, (LPARAM)lstrlen( pTok->szText)); }
/**********************************************************************
*FUNCTION: SaveMtkList(HWND) * * * *PURPOSE: Save current Token List * * * *COMMENTS: * * * *This saves the current contents of the Token List * **********************************************************************/
static BOOL SaveMtkList(HWND hWnd, FILE *fpTokFile) { BOOL bSuccess = TRUE; int IOStatus; // result of a file write
UINT cTokens; UINT cCurrentTok = 0; TCHAR *szTmpBuf; CHAR *szTokBuf; TCHAR str[255] = TEXT(""); TOKENDELTAINFO FAR *pTokNode; LPTSTR lpstrToken;
// Set the cursor to an hourglass during the file transfer
hSaveCursor = SetCursor(hHourGlass);
// Find number of tokens in the list
cTokens = (UINT) SendMessage( hListWnd, LB_GETCOUNT, (WPARAM)0, (LPARAM)0);
if (cTokens != LB_ERR) { for (cCurrentTok = 0; bSuccess && (cCurrentTok < cTokens); cCurrentTok++) { #ifdef UNICODE
int nLenW = 0; int nLenA = 0; #endif
// Get each token from list
HGLOBAL hMem = (HGLOBAL)SendMessage( hListWnd, LB_GETITEMDATA, (WPARAM)cCurrentTok, (LPARAM)0); lpstrToken = (LPTSTR)GlobalLock( hMem);
#ifdef UNICODE
nLenW = lstrlen( lpstrToken) + 1; szTmpBuf = (TCHAR *)FALLOC( (nLenA = MEMSIZE( nLenW))); lstrcpy( szTmpBuf, lpstrToken); GlobalUnlock( hMem); szTokBuf = (CHAR *)FALLOC( nLenA); _WCSTOMBS( szTokBuf, szTmpBuf, nLenA, nLenW); RLFREE( szTmpBuf); #else
szTokBuf = (CHAR *)FALLOC( strlen( lpstrToken) + 1); lstrcpy( szTokBuf, lpstrToken); #endif
IOStatus = fprintf(fpTokFile, "%s\n", szTokBuf);
if ( IOStatus != (int) strlen(szTokBuf) + 1 ) { LoadString( hInst, IDS_FILESAVEERR, str, TCHARSIN( sizeof( str))); MessageBox( hWnd, str, NULL, MB_OK | MB_ICONHAND); bSuccess = FALSE; } RLFREE( szTokBuf); } }
pTokNode = pTokenDeltaInfo;
while (pTokNode) { TOKEN *pTok; int nLenW = 0; int nLenA = 0;
pTok = &(pTokNode->DeltaToken);
#ifdef UNICODE
nLenW = TokenToTextSize( pTok); szTmpBuf = (TCHAR *)FALLOC( (nLenA = MEMSIZE( nLenW))); ParseTokToBuf( szTmpBuf, pTok); szTokBuf = (CHAR *)FALLOC( nLenA); _WCSTOMBS( szTokBuf, szTmpBuf, nLenA, nLenW); RLFREE( szTmpBuf); #else
szTokBuf = (CHAR *)FALLOC( TokenToTextSize( pTok)); ParseTokToBuf( szTokBuf, pTok); #endif
IOStatus = fprintf(fpTokFile, "%s\n", szTokBuf);
if ( IOStatus != (int) strlen(szTokBuf) + 1 ) { LoadString( hInst, IDS_FILESAVEERR, str, TCHARSIN( sizeof(str))); MessageBox( hWnd, str, NULL, MB_OK | MB_ICONHAND); bSuccess = FALSE; } pTokNode = pTokNode->pNextTokenDelta; }
// restore cursor
SetCursor(hSaveCursor);
return (bSuccess); }
/**
* Function: CleanDeltaList * frees the pTokenDeltaInfo list */ static void CleanDeltaList(void) { TOKENDELTAINFO FAR *pTokNode;
while (pTokNode = pTokenDeltaInfo) { pTokenDeltaInfo = pTokNode->pNextTokenDelta; RLFREE( pTokNode->DeltaToken.szText); RLFREE( pTokNode); } }
static TOKENDELTAINFO FAR *InsertMtkList(FILE * fpTokFile) { TOKENDELTAINFO FAR * ptTokenDeltaInfo, FAR * pTokenDeltaInfo = NULL; int scTokStat; TOKEN tToken; UINT wcChars = 0; LPTSTR lpstrToken;
rewind(fpTokFile);
while ( (scTokStat = GetToken( fpTokFile, &tToken)) >= 0 ) { if ( scTokStat == 0 ) { if ( tToken.wReserved != ST_CHANGED ) { HGLOBAL hMem = GlobalAlloc( GMEM_ZEROINIT, MEMSIZE( TokenToTextSize( &tToken))); lpstrToken = (LPTSTR)GlobalLock( hMem); ParseTokToBuf( lpstrToken, &tToken); GlobalUnlock( hMem); // only add tokens that aren't changed && old
if ( SendMessage( hListWnd, LB_ADDSTRING, (WPARAM)0, (LPARAM)hMem) < 0 ) { QuitA( IDS_ENGERR_11, NULL, NULL); } } else { // the current token is delta info so save in delta list.
if (!pTokenDeltaInfo) { ptTokenDeltaInfo = pTokenDeltaInfo = UpdateTokenDeltaInfo(&tToken); } else { ptTokenDeltaInfo->pNextTokenDelta = UpdateTokenDeltaInfo(&tToken); ptTokenDeltaInfo = ptTokenDeltaInfo->pNextTokenDelta; } } RLFREE( tToken.szText); } }
return(pTokenDeltaInfo); }
/*
* About -- message processor for about box * */ //#ifdef RLWIN32
INT_PTR CALLBACK About(
HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam) { switch( message ) { case WM_INITDIALOG: { WORD wRC = SUCCESS; CHAR szModName[ MAXFILENAME];
GetModuleFileNameA( hInst, szModName, sizeof( szModName));
if ( (wRC = GetCopyright( szModName, szDHW, DHWSIZE)) == SUCCESS ) { SetDlgItemTextA( hDlg, IDC_COPYRIGHT, szDHW); } else { ShowErr( wRC, NULL, NULL); } } break;
case WM_COMMAND:
if ((wParam == IDOK) || (wParam == IDCANCEL)) { EndDialog(hDlg, TRUE); } break;
default:
return( FALSE); } return( TRUE); }
//...................................................................
int RLMessageBoxA(
LPCSTR pszMsgText) { return( MessageBoxA( hMainWnd, pszMsgText, szAppName, MB_ICONHAND|MB_OK)); }
//...................................................................
void Usage() { return; }
//...................................................................
void DoExit( int nErrCode) { ExitProcess( (UINT)nErrCode); }
|