2020-09-30 17:12:32 +02:00

191 lines
4.9 KiB
C

/*
* edslRare.c - SL Edit controls Routines Called rarely are to be
* put in a seperate segment _EDSLRare. This file contains
* these routines.
* Copyright (c) 1985 - 1999, Microsoft Corporation
* Single-Line Support Routines called Rarely
* Created: 02-08-89 sankar
*/
#include "precomp.h"
#pragma hdrstop
/*
* SLCreate
* Creates the edit control for the window hwnd by allocating memory
* as required from the application's heap. Notifies parent if no memory
* error (after cleaning up if needed). Returns TRUE if no error else return s
* -1.
* History:
*/
LONG SLCreate(
PED ped,
LPCREATESTRUCT lpCreateStruct) //!!! CREATESTRUCT AorW and in other routines
{
LPSTR lpWindowText;
LONG windowStyle = ped->pwnd->style;
/*
* Do the standard creation stuff
*/
if (!ECCreate(ped, windowStyle))
return (-1);
/*
* Single lines always have no undo and 1 line
*/
ped->cLines = 1;
ped->undoType = UNDO_NONE;
/*
* Check if this edit control is part of a combobox and get a pointer to the
* combobox structure.
*/
if (windowStyle & ES_COMBOBOX)
ped->listboxHwnd = GetDlgItem(lpCreateStruct->hwndParent, CBLISTBOXID);
/*
* Set the default font to be the system font.
*/
ECSetFont(ped, NULL, FALSE);
/*
* Set the window text if needed. Return false if we can't set the text
* SLSetText notifies the parent in case there is a no memory error.
*/
if ((ULONG_PTR)lpCreateStruct->lpszName > gHighestUserAddress)
lpWindowText = REBASEPTR(ped->pwnd, (PVOID)lpCreateStruct->lpszName);
else
lpWindowText = (LPSTR)lpCreateStruct->lpszName;
if ((lpWindowText != NULL)
&& !IsEmptyString(lpWindowText, ped->fAnsi)
&& !ECSetText(ped, lpWindowText)) {
return (-1);
}
if (windowStyle & ES_PASSWORD)
ECSetPasswordChar(ped, (UINT)'*');
return TRUE;
}
/*
* SLUndoHandler AorW
* Handles UNDO for single line edit controls.
* History:
*/
BOOL SLUndo(
PED ped)
{
PBYTE hDeletedText = ped->hDeletedText;
BOOL fDelete = (BOOL)(ped->undoType & UNDO_DELETE);
ICH cchDeleted = ped->cchDeleted;
ICH ichDeleted = ped->ichDeleted;
BOOL fUpdate = FALSE;
if (ped->undoType == UNDO_NONE) {
/*
* No undo...
*/
return FALSE;
}
ped->hDeletedText = NULL;
ped->cchDeleted = 0;
ped->ichDeleted = (ICH)-1;
ped->undoType &= ~UNDO_DELETE;
if (ped->undoType == UNDO_INSERT) {
ped->undoType = UNDO_NONE;
/*
* Set the selection to the inserted text
*/
SLSetSelection(ped, ped->ichInsStart, ped->ichInsEnd);
ped->ichInsStart = ped->ichInsEnd = (ICH)-1;
#ifdef NEVER
/*
* Now send a backspace to deleted and save it in the undo buffer...
*/
SLCharHandler(pped, VK_BACK);
fUpdate = TRUE;
#else
/*
* Delete the selected text and save it in undo buff.
* Call ECDeleteText() instead of sending a VK_BACK message
* which results in an EN_UPDATE notification send even before
* we insert the deleted chars. This results in Bug #6610.
* Fix for Bug #6610 -- SANKAR -- 04/19/91 --
*/
if (ECDeleteText(ped)) {
/*
* Text was deleted -- flag for update and clear selection
*/
fUpdate = TRUE;
SLSetSelection(ped, ichDeleted, ichDeleted);
}
#endif
}
if (fDelete) {
HWND hwndSave = ped->hwnd; // Used for validation.
/*
* Insert deleted chars. Set the selection to the inserted text.
*/
SLSetSelection(ped, ichDeleted, ichDeleted);
SLInsertText(ped, hDeletedText, cchDeleted);
UserGlobalFree(hDeletedText);
if (!IsWindow(hwndSave))
return FALSE;
SLSetSelection(ped, ichDeleted, ichDeleted + cchDeleted);
fUpdate = TRUE;
}
if (fUpdate) {
/*
* If we have something to update, send EN_UPDATE before and
* EN_CHANGE after the actual update.
* A part of the fix for Bug #6610 -- SANKAR -- 04/19/91 --
*/
ECNotifyParent(ped, EN_UPDATE);
if (FChildVisible(ped->hwnd)) {
// JimA changed this to ECInvalidateClient(ped, FALSE) Nov 1994
// GetClientRect(ped->hwnd, &rcEdit);
// if (ped->fBorder && rcEdit.right - rcEdit.left && rcEdit.bottom - rcEdit.top) {
// /*
// * Don't invalidate the border so that we avoid flicker
// */
// InflateRect(&rcEdit, -1, -1);
// }
// NtUserInvalidateRect(ped->hwnd, &rcEdit, FALSE);
ECInvalidateClient(ped, FALSE);
}
ECNotifyParent(ped, EN_CHANGE);
if (FWINABLE()) {
NotifyWinEvent(EVENT_OBJECT_VALUECHANGE, ped->hwnd, OBJID_CLIENT, INDEXID_CONTAINER);
}
}
return TRUE;
}