/* * $Id$ */ /* * Harbour Project source code: * Header file for the Virtual Machine API * * Copyright 1999 Antonio Linares * www - http://www.harbour-project.org * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version, with one exception: * * The exception is that if you link the Harbour Runtime Library (HRL) * and/or the Harbour Virtual Machine (HVM) with other files to produce * an executable, this does not by itself cause the resulting executable * to be covered by the GNU General Public License. Your use of that * executable is in no way restricted on account of linking the HRL * and/or HVM code into it. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA (or visit * their web site at http://www.gnu.org/). * */ #ifndef HB_VM_H_ #define HB_VM_H_ #include "hbapi.h" #if defined(HB_EXTERN_C) extern "C" { #endif /* Harbour virtual machine init/exit functions */ extern void hb_vmInit( BOOL bStartMainProc ); extern void hb_vmQuit( void ); /* Harbour virtual machine functions */ extern void hb_vmExecute( BYTE * pCode, PHB_SYMB pSymbols ); /* invokes the virtual machine */ extern void hb_vmProcessSymbols( PHB_SYMB pSymbols, USHORT uiSymbols ); /* statics symbols initialization */ extern void hb_vmSymbolInit_RT( void ); /* initialization of runtime support symbols */ /* Harbour virtual machine escaping API */ extern void hb_vmRequestQuit( void ); extern void hb_vmRequestEndProc( void ); extern void hb_vmRequestCancel( void ); extern void hb_vmRequestBreak( PHB_ITEM pItem ); extern USHORT hb_vmRequestQuery( void ); extern void hb_vmQuit( void ); /* Immediately quits the virtual machine */ /* Return values of hb_vmRequestQuery() */ #define HB_QUIT_REQUESTED 1 /* immediately quit the application */ #define HB_BREAK_REQUESTED 2 /* break to nearest RECOVER/END sequence */ #define HB_ENDPROC_REQUESTED 4 /* immediately return from procedure (error handler in macro evaluation) */ /* Public PCode functions */ /* Object */ extern void hb_vmMessage( PHB_SYMB pSymMsg ); /* sends a message to an object */ /* Execution */ extern void hb_vmDo( USHORT uiParams ); /* invoke the virtual machine */ extern void hb_vmFunction( USHORT uiParams ); /* executes a function saving its result */ /* Push */ extern void hb_vmPush( PHB_ITEM pItem ); /* pushes a generic item onto the stack */ extern void hb_vmPushNil( void ); /* in this case it places nil at self */ extern void hb_vmPushNumber( double dNumber, int iDec ); /* pushes a number on to the stack and decides if it is integer, long or double */ extern void hb_vmPushInteger( int iNumber ); /* pushes a integer number onto the stack */ extern void hb_vmPushLong( long lNumber ); /* pushes a long number onto the stack */ extern void hb_vmPushDouble( double lNumber, int iDec ); /* pushes a double number onto the stack */ extern void hb_vmPushLogical( BOOL bValue ); /* pushes a logical value onto the stack */ extern void hb_vmPushString( char * szText, ULONG length ); /* pushes a string on to the stack */ extern void hb_vmPushDate( long lDate ); /* pushes a long date onto the stack */ extern void hb_vmPushSymbol( PHB_SYMB pSym ); /* pushes a function pointer onto the stack */ /* stack management functions */ extern void hb_stackDispCall( void ); extern void hb_stackPop( void ); /* pops an item from the stack */ #if defined(HB_EXTERN_C) } #endif #endif /* HB_VM_H_ */