Отменяет самое последнее изменение, внесенное в файл в заданном окне.
void _EdUndo(WHANDLE wh) WHANDLE wh; /* Дескриптор окна редактирования. */ |
Примечания
Когда пользователь вносит в файл изменения, они записываются в буфер отмены. _EdUndo( ) можно вызвать несколько раз и тем самым отменить целую группу изменений. Нельзя отменить изменение, внесенное до вызова _EdSave( ).
Для получения дополнительной информации о том, как создавать библиотеку API и интегрировать её в Visual FoxPro, смотрите Доступ к Visual FoxPro API..
Пример
В следующем примере открывается для редактирования файл, заданный параметром. Вставляется новая строка, затем она удаляется с помощью _EdUndo( ), после чего эта строка восстанавливается с помощью _EdRedo( ).
Код Visual FoxPro
![]() | |
---|---|
SET LIBRARY TO EDUNDO = EDREDO("x") |
Код C
![]() | |
---|---|
#include <pro_ext.h> FAR Example(ParamBlk FAR *parm) { #define pFILENAME ((char FAR *) _HandToPtr(parm->p[0].val.ev_handle)) WHANDLE wh; if (!_SetHandSize(parm->p[0].val.ev_handle, parm->p[0].val.ev_length+1)) { _Error(182); // "Insufficient memory" } pFILENAME[parm->p[0].val.ev_length] = '\0'; _HLock(parm->p[0].val.ev_handle); wh = _EdOpenFile(pFILENAME, FO_READWRITE); _HUnLock(parm->p[0].val.ev_handle); _EdSetPos(wh, _EdGetLinePos(wh, 13)); _EdInsert(wh, "Hello, world\n", _StrLen("Hello, world\n")); _Execute("WAIT WINDOW 'New line inserted.\ Press any key to undo.'"); _EdUndo(wh); _Execute("WAIT WINDOW 'Insertion undone. Press any key to redo.'"); _EdRedo(wh); } FoxInfo myFoxInfo[] = { {"EDREDO", (FPFI) Example, 1, "C"}, }; FoxTable _FoxTable = { (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo }; |