Компилирует и выполняет заданный в параметре 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
Замечание