Компилирует и выполняет заданный в параметре stmt оператор, ограниченный нуль-символом.
int _Execute(char FAR *stmt)
char FAR *stmt; /* Выполняемый оператор. */ |
Примечания
Параметр stmt может задавать любую команду или функцию, которую можно выполнить из окна Command. Когда выполнение оператора завершается, управление обычно возвращается оператору языка C, непосредственно следующему за вызовом _Execute( ). Исключение составляет выполнение кода для команды Visual FoxPro CANCEL или QUIT.
_Execute( ) возвращает внутренний номер ошибки Visual FoxPro, которая может произойти во время выполнения оператора; если ошибок нет, возвращается 0.
Замечание |
---|
Не вызывайте _Execute( ) из обработчика событий. |
Для получения дополнительной информации о том, как создавать библиотеку API и интегрировать её в Visual FoxPro, смотрите Доступ к API Visual FoxPro.
Пример
В следующем примере программа _Execute( ) используется для выполнения переданного оператора Visual FoxPro.
Код Visual FoxPro
Copy Code | |
---|---|
SET LIBRARY TO EXECUTE = EXEC("? 'Hello, world.'") = EXEC("DISPLAY STATUS") |
Код C
Copy Code | |
---|---|
#include <pro_ext.h> FAR ExecuteEx(ParamBlk FAR *parm) { char FAR *cmd; // Null terminate character string if (!_SetHandSize(parm->p[0].val.ev_handle, parm->p[0].val.ev_length+1)) { _Error(182); // "Insufficient memory" } _HLock(parm->p[0].val.ev_handle); cmd = (char FAR *) _HandToPtr(parm->p[0].val.ev_handle); cmd[parm->p[0].val.ev_length] = '\0'; _Execute(cmd); _HUnLock(parm->p[0].val.ev_handle); } FoxInfo myFoxInfo[] = { {"EXEC", (FPFI) ExecuteEx, 1, "C"}, }; FoxTable _FoxTable = { (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo }; |
Смотрите также
Справочное руководство
Процедура библиотеки API _Evaluate( )Команда CANCEL
Команда QUIT
Прочие ресурсы
Конструкции библиотеки APIДоступ к API Visual FoxPro