* harbour/bin/hb-func.sh
* added support -go[0-3] and other -g* switches to xhb* scripts
* harbour/include/hbapi.h
+ added ISSYMBOL() macro
* formatting
* harbour/include/hbapirdd.h
* changed definition of SUPERTABLE for optional dynamic overloading
this modification will not effect existing code
* harbour/include/hbrddfpt.h
* harbour/source/rdd/dbffpt/dbffpt1.c
* added support for NIL value in SIX3 FPT files
* harbour/include/hbcomp.h
* harbour/source/compiler/harbour.c
* harbour/source/compiler/genc.c
* harbour/source/compiler/gencli.c
* harbour/source/compiler/genhrb.c
* harbour/source/compiler/genjava.c
! message symbols are not function symbols - cleaned the HB_FS_MESSAGE
usage and fix the problem with registering static function in global
symbol table
* harbour/source/compiler/gencc.c
! fixed typo in compilation for platforms 64 bit LONG
* harbour/include/hbvmpub.h
* harbour/source/compiler/cmdcheck.c
* harbour/source/vm/asort.c
* harbour/source/vm/evalhb.c
* formatting
* harbour/source/rdd/dbcmd.c
* formatting and some minor clean-up
* harbour/source/rdd/workarea.c
* added default SYSNAME method
! fixed possible memory leak when APPEND failed in TRANSREC method
* harbour/source/rdd/hsx/hsx.c
! fixed using HS_ADD()/HS_REPLACE() without STRING/BLOCK expression
* harbour/source/rtl/cdpapi.c
* cleaned GCC4 warning
* harbour/source/rtl/do.c
* changed to keep parameter references in DO() function. Now it works
like IIF()/EVAL()
* harbour/source/vm/classes.c
* removed some definitions repared from hbapi.h
+ added support to passing function references as HB_IT_SYMBOL
* harbour/source/vm/dynlibhb.c
! fixed GPF in HB_LIBDO called with wrong parameter
* harbour/source/vm/hvm.c
! fixed hb_rddGetFieldValue() to not operate on unallocated stack area
it could cause unpredictable results when RDD had to access HVM, f.e.
for evaluation some pending relations. The whole code should be
carefully checked and to not operate on hb_stackTopItem() if other
functions are called to make the HVM fully reentrant.
+ added commented out support for passing HB_IT_SYMBOL as function
pointer
* formatting
* harbour/source/vm/itemapi.c
* return "S" for HB_IT_SYMBOL by hb_itemType()
* formatting
190 lines
6.5 KiB
C
190 lines
6.5 KiB
C
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* Harbour Project source code:
|
|
* Header file for the generated C language source code
|
|
*
|
|
* Copyright 1999-2001 Viktor Szakats <viktor.szakats@syenar.hu>
|
|
* 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, or (at your option)
|
|
* any later version.
|
|
*
|
|
* 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 software; see the file COPYING. If not, write to
|
|
* the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
|
* Boston, MA 02111-1307 USA (or visit the web site http://www.gnu.org/).
|
|
*
|
|
* As a special exception, the Harbour Project gives permission for
|
|
* additional uses of the text contained in its release of Harbour.
|
|
*
|
|
* The exception is that, if you link the Harbour libraries 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 Harbour library code into it.
|
|
*
|
|
* This exception does not however invalidate any other reasons why
|
|
* the executable file might be covered by the GNU General Public License.
|
|
*
|
|
* This exception applies only to the code released by the Harbour
|
|
* Project under the name Harbour. If you copy code from other
|
|
* Harbour Project or Free Software Foundation releases into a copy of
|
|
* Harbour, as the General Public License permits, the exception does
|
|
* not apply to the code that you add in this way. To avoid misleading
|
|
* anyone as to the status of such modified files, you must delete
|
|
* this exception notice from them.
|
|
*
|
|
* If you write modifications of your own for Harbour, it is your choice
|
|
* whether to permit this exception to apply to your modifications.
|
|
* If you do not wish that, delete this exception notice.
|
|
*
|
|
*/
|
|
|
|
#ifndef HB_VMPUB_H_
|
|
#define HB_VMPUB_H_
|
|
|
|
#include "hbdefs.h"
|
|
|
|
HB_EXTERN_BEGIN
|
|
|
|
#ifdef _HB_API_INTERNAL_
|
|
|
|
struct _HB_SYMB;
|
|
|
|
# define HB_ITEM_TYPE( p ) ( ( p )->type )
|
|
# define HB_OBJ_CLASS( p ) ( ( p )->item.asArray.value->uiClass )
|
|
|
|
# if defined(__GNUC__)
|
|
# define HB_ITEM_NIL { HB_IT_NIL, {} }
|
|
# else
|
|
# define HB_ITEM_NIL { HB_IT_NIL, NULL }
|
|
# endif
|
|
|
|
# define HB_ITEM_GET_NUMINTRAW( p ) ( HB_IS_INTEGER( p ) ? \
|
|
( HB_LONG ) p->item.asInteger.value : \
|
|
( HB_LONG ) p->item.asLong.value )
|
|
|
|
# define HB_ITEM_PUT_NUMINTRAW( p, v ) \
|
|
do { \
|
|
if( HB_LIM_INT( v ) ) \
|
|
{ \
|
|
(p)->type = HB_IT_INTEGER; \
|
|
(p)->item.asInteger.length = HB_INT_LENGTH( v ); \
|
|
(p)->item.asInteger.value = ( int ) (v); \
|
|
} \
|
|
else \
|
|
{ \
|
|
(p)->type = HB_IT_LONG; \
|
|
(p)->item.asLong.value = (v); \
|
|
(p)->item.asLong.length = HB_LONG_LENGTH( v ); \
|
|
} \
|
|
} while ( 0 )
|
|
|
|
/* dynamic symbol structure */
|
|
typedef struct _HB_DYNS
|
|
{
|
|
struct _HB_SYMB * pSymbol; /* pointer to its relative local symbol */
|
|
PHB_FUNC pFunPtr; /* Pointer to the function address */
|
|
HB_HANDLE hArea; /* Workarea number */
|
|
HB_HANDLE hMemvar; /* Index number into memvars ( publics & privates ) array */
|
|
ULONG ulCalls; /* profiler support */
|
|
ULONG ulTime; /* profiler support */
|
|
ULONG ulRecurse; /* profiler support */
|
|
} HB_DYNS, * PHB_DYNS, * HB_DYNS_PTR;
|
|
|
|
#else
|
|
|
|
# undef HB_API_MACROS
|
|
# undef HB_STACK_MACROS
|
|
|
|
/* This is ugly trick but works without speed overhead */
|
|
# define HB_ITEM_TYPE( p ) ( * ( HB_TYPE * ) ( p ) )
|
|
|
|
/* if you do not like it then use this definition */
|
|
/* # define HB_ITEM_TYPE( p ) ( hb_itemType( p ) ) */
|
|
|
|
# define HB_OBJ_CLASS( p ) ( hb_objGetClass( p ) )
|
|
|
|
/* basic types */
|
|
typedef void * PHB_ITEM;
|
|
typedef void * HB_ITEM_PTR;
|
|
typedef void * HB_CODEBLOCK_PTR;
|
|
|
|
typedef void HB_STACK;
|
|
|
|
/*
|
|
* The first version reduce the number of modification in existing 3-rd
|
|
* party code but in longer terms I'd prefer to disable it and left
|
|
* only the second one where PHB_DYNS is mapped to void*.
|
|
* This will allow us to fully redesign dynamic symbol internals
|
|
* in the future if it will be necessary. [druzus]
|
|
*/
|
|
#if 0
|
|
struct _HB_SYMB;
|
|
typedef struct
|
|
{
|
|
struct _HB_SYMB * pSymbol; /* pointer to its relative local symbol */
|
|
} _HB_DYNS, * PHB_DYNS, * HB_DYNS_PTR;
|
|
#else
|
|
typedef void * PHB_DYNS;
|
|
typedef void * PHB_DYNS_PTR;
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
/* symbol support structure */
|
|
typedef struct _HB_SYMB
|
|
{
|
|
char * szName; /* the name of the symbol */
|
|
union
|
|
{
|
|
HB_SYMBOLSCOPE value; /* the scope of the symbol */
|
|
void * pointer; /* filler to force alignment */
|
|
} scope;
|
|
union
|
|
{
|
|
PHB_FUNC pFunPtr; /* function address for function symbol table entries */
|
|
int iStaticsBase; /* base offset to array of statics */
|
|
} value;
|
|
PHB_DYNS pDynSym; /* pointer to its dynamic symbol if defined */
|
|
} HB_SYMB, * PHB_SYMB;
|
|
|
|
#define HB_DYNS_FUNC( hbfunc ) BOOL hbfunc( PHB_DYNS pDynSymbol, void * Cargo )
|
|
typedef HB_DYNS_FUNC( PHB_DYNS_FUNC );
|
|
|
|
typedef void (*HB_INIT_FUNC)(void *);
|
|
/* List of functions used by hb_vmAtInit()/hb_vmAtExit() */
|
|
typedef struct _HB_FUNC_LIST
|
|
{
|
|
HB_INIT_FUNC pFunc;
|
|
void * cargo;
|
|
struct _HB_FUNC_LIST * pNext;
|
|
} HB_FUNC_LIST, * PHB_FUNC_LIST;
|
|
|
|
/* Harbour Functions scope ( HB_SYMBOLSCOPE ) */
|
|
#define HB_FS_PUBLIC ( ( HB_SYMBOLSCOPE ) 0x01 )
|
|
#define HB_FS_STATIC ( ( HB_SYMBOLSCOPE ) 0x02 )
|
|
#define HB_FS_FIRST ( ( HB_SYMBOLSCOPE ) 0x04 )
|
|
#define HB_FS_INIT ( ( HB_SYMBOLSCOPE ) 0x08 )
|
|
#define HB_FS_EXIT ( ( HB_SYMBOLSCOPE ) 0x10 )
|
|
#define HB_FS_INITEXIT ( HB_FS_INIT | HB_FS_EXIT )
|
|
#define HB_FS_MESSAGE ( ( HB_SYMBOLSCOPE ) 0x20 )
|
|
#define HB_FS_MEMVAR ( ( HB_SYMBOLSCOPE ) 0x80 )
|
|
|
|
extern HB_EXPORT void hb_vmExecute( const BYTE * pCode, PHB_SYMB pSymbols ); /* invokes the virtual machine */
|
|
|
|
HB_EXTERN_END
|
|
|
|
#endif /* HB_VMPUB_H_ */
|