Вставляет в позиции курсора заданное число байтов, расположенных по указанному адресу TEXT *.
void _EdInsert(WHANDLE wh, TEXT *theStr, unsigned long Bytes) WHANDLE wh; /* Дескриптор окна редактирования. */ TEXT *theStr; /* Адрес начала вставляемого текста. */ unsigned long Bytes; /* Число вставляемых байтов. */ |
Пример
следующем примере открывается сеанс редактирования для файла, заданного параметром, и в качестве его новой четырнадцатой строки вставляется текст "Hello, world".
Код Visual FoxPro
![]() | |
---|---|
SET LIBRARY TO EDINSERT = EDINSERT("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")); } FoxInfo myFoxInfo[] = { {"EDINSERT", (FPFI) Example, 1, "C"}, }; FoxTable _FoxTable = { (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo }; |
Смотрите также
Справочное руководство
Процедура библиотеки API _EdGetPos( )Процедура библиотеки API _EdSetPos( )
Прочие ресурсы
Конструкции библиотеки APIДоступ к API Visual FoxPro