Share via


_Execute( ) (Rutina de biblioteca API)

Compila y ejecuta la instrucción terminada en nulo especificada en stmt.

int _Execute(char FAR *stmt)
char FAR *stmt;            /* Statement to execute. */

Observaciones

El parámetro stmt puede ser cualquier comando o función que se pueda ejecutar desde la ventana Comandos. Cuando haya terminado la ejecución de la instrucción, el control suele volver a la instrucción C inmediatamente después de la llamada a _Execute( ). Entre las excepciones se incluye el código de ejecución que ejecuta un comando CANCEL o QUIT de Visual FoxPro.

_Execute( ) devuelve el número de error interno de Visual FoxPro para cualquier error que ocurra durante la ejecución de la instrucción o 0 si no ocurre ningún error.

Nota   No llame a _Execute( ) desde un controlador de eventos.

Para obtener más información acerca de cómo crear una biblioteca API e integrarla con Visual FoxPro, vea Acceso a la API de Visual FoxPro.

Ejemplo

El siguiente ejemplo utiliza _Execute( ) para ejecutar la instrucción de Visual FoxPro transferida.

Código Visual FoxPro

SET LIBRARY TO EXECUTE 
= EXEC("? 'Hello, world.'")
= EXEC("DISPLAY STATUS")

Código C

#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
};

Vea también

_Evaluate( ) (Rutina de biblioteca API) | CANCEL (Comando) | QUIT (Comando) | Acceso a la API de Visual FoxPro