Files
harbour-core/harbour/src/pp/pplib.c
Przemyslaw Czerpak a70ce60954 2009-10-23 09:24 UTC+0200 Przemyslaw Czerpak (druzus/at/priv.onet.pl)
* harbour/src/rdd/dbfnsx/dbfnsx1.c
    ! fixed bug reported by Jaroslav Janik (many thanks) - if index FOR
      expression excluded all records from non empty table then root page
      was not initialized and DBFNSX generated corruption RTE.

  * harbour/utils/hbi18n/hbi18n.prg
    * set default GT to CGI

  * harbour/src/common/hbgete.c
    ! fixed memory leak in non UNICODE Windows hb_getenv_buffer()
    ! add C stack buffers to eliminate memory allocation in UNICODE
      Windows hb_getenv_buffer() - they are used if envvar name and
      passed buffer are not too large. It fixes HB_FM_STATISTICS
      Windows builds.

  * harbour/contrib/hbwin/wapi_winuser.c
    + added WAPI_DESTROYWINDOW function

  * harbour/contrib/xhb/traceprg.prg
  * harbour/contrib/xhb/hbcompat.ch
    ! fixed typo in TraceLog() condition - was always disabled
    + added emulation for xHarbour Set( _SET_TRACE* [, <params,...> ] )
      settings

  * harbour/src/vm/hvmall.c
    ! define _GNU_SOURCE to fix compilation with HB_FM_DL_ALLOC in Linux
      builds

  * harbour/include/hbdefs.h
    * declare HB_FOFFSET as LONG instead of LONGLONG on platforms where
      LONG is 64bit integer to be compatible with C RTL file API

  * harbour/src/vm/maindllh.c
  * harbour/src/vm/maindllp.c
  * harbour/contrib/hbct/ctstr.c
    ! casting in HB_TRACE() massages

  * harbour/include/hbapi.h
  * harbour/include/hbapiitm.h
  * harbour/src/vm/arrays.c
  * harbour/src/vm/hashes.c
  * harbour/src/vm/itemapi.c
    + added hb_arrayCloneTo(), hb_hashCloneTo(), hb_itemCloneTo()

  * harbour/src/vm/arrayshb.c
  * harbour/src/vm/classes.c
  * harbour/src/vm/hashes.c
  * harbour/src/vm/hashfunc.c
  * harbour/src/vm/hvm.c
    % use hb_*CloneTo() instead of hb_*Clone()

  * harbour/include/hbapi.h
  * harbour/src/vm/garbage.c
    - removed hb_gcRegisterSweep() function and support for user defined
      sweep mark functions in GC blocks
    - removed hb_gcAlloc() function
    + added new function hb_gcAllocate() which work in similar way to removed
      hb_gcAlloc() function but it accepts as second parameter HB_GC_FUNCS
      structure instead of HB_GARBAGE_FUNC_PTR and returned GC blocks are
      locked so programmer does not have to worry that they can be removed
      by GC.
    + added new internal function hb_gcAllocRaw() which works like
      hb_gcAllocate() but returned GC blocks are not locked. They can
      be used only in HVM in places well known that cannot activate
      automatic GC scan. It should not be used by 3-rd party code.

  * harbour/include/hbapi.h
  * harbour/include/hbapiitm.h
  * harbour/src/vm/extend.c
  * harbour/src/vm/itemapi.c
    * modified hb_parptrGC(), hb_parvptrGC(), hb_arrayGetPtrGC(),
      hb_itemGetPtrGC() functions to use HB_GC_FUNCS structure instead
      of HB_GARBAGE_FUNC_PTR
    * modified hb_itemPutPtrGC() and indirectly related functions like
      hb_arraySetPtrGC() or hb_stor[v]ptrGC() to automatically unlock
      passed GC block just after attaching to known HVM item.

  * harbour/include/hbregex.h
  * harbour/src/rtl/hbregexc.c
    * declare GC block detractor as static function
    + added hb_regexIs() function
    * updated to work with new GC API
    * removed unnecessary in new GC API hb_gcLock() call - GC blocks
      allocated by hb_gcAllocate() are already locked and they mustn't
      be locked explicitly by programmer (until he does not exactly knows
      what he does ;))

  * harbour/src/rtl/hbregex.c
    * use hb_regexIs() instead of using regex GC destructor
    * removed unnecessary in new GC API hb_gcUnlock() call - GC blocks
      stored in HB_IT_POINTER item are automatically unlocked

  * harbour/src/rtl/hbinet.c
  * harbour/contrib/hbcurl/hbcurl.c
    * updated to work with new GC API
    % unlock items storing callback codeblocks and use GC mark functions
      to mark them as used in GC passes

  * harbour/src/pp/pplib.c
  * harbour/src/vm/runner.c
  * harbour/src/vm/codebloc.c
  * harbour/src/vm/hashes.c
  * harbour/src/vm/hvm.c
  * harbour/src/vm/arrays.c
  * harbour/src/vm/thread.c
  * harbour/src/vm/dynlibhb.c
  * harbour/src/rtl/hbzlibgz.c
  * harbour/src/rtl/hbregex.c
  * harbour/src/rtl/hbregexc.c
  * harbour/src/rtl/hbgtcore.c
  * harbour/src/rtl/hbi18n1.c
  * harbour/src/rdd/wacore.c
  * harbour/contrib/hbsqlit3/hbsqlit3.c
  * harbour/contrib/hbnetio/netiosrv.c
  * harbour/contrib/hbmzip/hbmzip.c
  * harbour/contrib/hbhpdf/harupdf.c
  * harbour/contrib/hbwin/olecore.c
  * harbour/contrib/hbwin/win_prn1.c
  * harbour/contrib/hbwin/win_dll.c
    * updated code which was using hb_gcAlloc() to work with new GC API.

  * harbour/contrib/hbwin/axcore.c
    * updated syntax description

   TODO: update contrib code: hbqt, hbssl, ... to work with new GC API.
         I would like to ask authors of above libraries to do it.
   TODO: defined when and how we should free AX control and user callback
         handler and update AX code to respect new definition
2009-10-23 07:25:36 +00:00

292 lines
7.9 KiB
C

/*
* $Id$
*/
/*
* Harbour Project source code:
* .prg interface to preprocessor
*
* Copyright 2006 Przemyslaw Czerpak <druzus / at / priv.onet.pl>
* 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.
*
*/
#include "hbpp.h"
#include "hbapi.h"
#include "hbapiitm.h"
#include "hbapifs.h"
#include "hbapierr.h"
#include "hbvm.h"
HB_EXTERN_BEGIN
static HB_GARBAGE_FUNC( hb_pp_Destructor );
static void hb_pp_ErrorMessage( void * cargo, const char * szMsgTable[],
char cPrefix, int iCode,
const char * szParam1, const char * szParam2 );
static void hb_pp_Disp( void * cargo, const char * szMessage );
static BOOL hb_pp_CompilerSwitch( void * cargo, const char * szSwitch,
int iValue );
HB_EXTERN_END
static void hb_pp_ErrorMessage( void * cargo, const char * szMsgTable[],
char cPrefix, int iCode,
const char * szParam1, const char * szParam2 )
{
HB_TRACE(HB_TR_DEBUG, ("hb_pp_ErrorGen(%p, %p, %c, %d, %s, %s)", cargo, szMsgTable, cPrefix, iCode, szParam1, szParam2));
HB_SYMBOL_UNUSED( cargo );
/* ignore all warning messages and errors when break or quit request */
if( cPrefix != 'W' && hb_vmRequestQuery() == 0 )
{
char szMsgBuf[ 1024 ];
PHB_ITEM pError;
hb_snprintf( szMsgBuf, sizeof( szMsgBuf ), szMsgTable[ iCode - 1 ],
szParam1, szParam2 );
pError = hb_errRT_New( ES_ERROR, "PP", 1001, ( ULONG ) iCode, szMsgBuf,
NULL, 0, EF_NONE | EF_CANDEFAULT );
hb_errLaunch( pError );
hb_errRelease( pError );
}
}
static void hb_pp_Disp( void * cargo, const char * szMessage )
{
/* ignore stdout messages when PP used as library */
HB_SYMBOL_UNUSED( cargo );
HB_SYMBOL_UNUSED( szMessage );
}
static BOOL hb_pp_CompilerSwitch( void * cargo, const char * szSwitch,
int iValue )
{
/* ignore all compiler switches */
HB_SYMBOL_UNUSED( cargo );
HB_SYMBOL_UNUSED( szSwitch );
HB_SYMBOL_UNUSED( iValue );
return FALSE;
}
/* PP destructor */
static HB_GARBAGE_FUNC( hb_pp_Destructor )
{
PHB_PP_STATE * pStatePtr = ( PHB_PP_STATE * ) Cargo;
if( * pStatePtr )
{
hb_pp_free( * pStatePtr );
* pStatePtr = NULL;
}
}
static const HB_GC_FUNCS s_gcPPFuncs =
{
hb_pp_Destructor,
hb_gcDummyMark
};
static void hb_pp_StdRules( PHB_ITEM ppItem )
{
static BOOL s_fInit = TRUE;
static PHB_DYNS s_pDynSym;
if( s_fInit )
{
s_pDynSym = hb_dynsymFind( "__PP_STDRULES" );
s_fInit = FALSE;
}
if( s_pDynSym )
{
hb_vmPushDynSym( s_pDynSym );
hb_vmPushNil();
hb_vmPush( ppItem );
hb_vmProc( 1 );
}
}
PHB_PP_STATE hb_pp_Param( int iParam )
{
PHB_PP_STATE * pStatePtr =
( PHB_PP_STATE * ) hb_parptrGC( &s_gcPPFuncs, iParam );
if( pStatePtr )
return * pStatePtr;
else
return NULL;
}
/*
* initialize new PP context and return pointer to it.
* __PP_INIT( [<cIncludePath>], [<cStdChFile> ] [, <lArchDefs>] )
* when <cStdChFile> is empty string ("") then no default rules are used
* only the dynamically created #defines like __HARBOUR__, __DATE__, __TIME__
*/
HB_FUNC( __PP_INIT )
{
PHB_PP_STATE * pStatePtr, pState = hb_pp_new();
if( pState )
{
const char * szPath = hb_parc( 1 ), * szStdCh = hb_parc( 2 );
BOOL fArchDefs = !ISLOG( 3 ) || hb_parl( 3 );
PHB_ITEM ppItem;
pStatePtr = ( PHB_PP_STATE * ) hb_gcAllocate( sizeof( PHB_PP_STATE ),
&s_gcPPFuncs );
* pStatePtr = pState;
ppItem = hb_itemPutPtrGC( NULL, ( void * ) pStatePtr );
hb_pp_init( pState, TRUE, 0, NULL, NULL, NULL,
hb_pp_ErrorMessage, hb_pp_Disp, NULL, NULL,
hb_pp_CompilerSwitch );
if( szPath )
hb_pp_addSearchPath( pState, szPath, TRUE );
if( !szStdCh )
hb_pp_StdRules( ppItem );
else if( *szStdCh )
hb_pp_readRules( pState, szStdCh );
hb_pp_initDynDefines( pState, fArchDefs );
hb_pp_setStdBase( pState );
hb_itemReturnRelease( ppItem );
}
else
hb_ret();
}
/*
* add new (or replace previous) include paths.
* __PP_PATH( <pPP>, <cPath> [, <lClearPrev>] )
*/
HB_FUNC( __PP_PATH )
{
PHB_PP_STATE pState = hb_pp_Param( 1 );
if( pState )
hb_pp_addSearchPath( pState, hb_parc( 2 ), hb_parl( 3 ) );
}
/*
* reset the PP context (remove all rules added by user or preprocessed code)
* __PP_RESET( <pPP> )
*/
HB_FUNC( __PP_RESET )
{
PHB_PP_STATE pState = hb_pp_Param( 1 );
if( pState )
hb_pp_reset( pState );
}
/*
* preprocess and execute new preprocessor directive
* __PPADDRULE( <pPP>, <cDirective> )
*/
HB_FUNC( __PP_ADDRULE )
{
PHB_PP_STATE pState = hb_pp_Param( 1 );
if( pState )
{
const char * szText = hb_parc( 2 );
ULONG ulLen = hb_parclen( 2 );
if( szText )
{
while( ulLen && ( szText[ 0 ] == ' ' || szText[ 0 ] == '\t' ) )
{
++szText;
--ulLen;
}
}
if( szText && ulLen && szText[ 0 ] == '#' )
{
hb_pp_parseLine( pState, szText, &ulLen );
/* probably for parsing #included files the old code was making
sth like that */
do
{
if( hb_vmRequestQuery() != 0 )
return;
}
while( hb_pp_nextLine( pState, NULL ) );
hb_retl( TRUE );
return;
}
}
hb_retl( FALSE );
}
/*
* preprocess given code and return result
* __PP_PROCESS( <pPP>, <cCode> ) -> <cPreprocessedCode>
*/
HB_FUNC( __PP_PROCESS )
{
PHB_PP_STATE pState = hb_pp_Param( 1 );
if( pState )
{
ULONG ulLen = hb_parclen( 2 );
if( ulLen )
{
char * szText = hb_pp_parseLine( pState, hb_parc( 2 ), &ulLen );
hb_retclen( szText, ulLen );
return;
}
}
hb_retc_null();
}