Files
harbour-core/harbour/source/compiler/genjava.c
Ron Pinkas 9e13451dde 20000420-20:10 GMT-8 Ron Pinkas <Ron@Profit-Master.com>
* source/compiler/harbour.c
     + Added hb_compOptimizeFrames() - Resolves and or removes HB_P_FRAME & HB_P_SFRAME.
     * Modified hb_compFixReturns() to call hb_compOptimizeFrames()

   * source/compiler/genc.c
     - Removed the SWITCH LOOP from hb_compGenCCompact()

   * source/compiler/genhrb.c
     - Removed the SWITCH LOOP from hb_compGenCCompact()

   * source/compiler/genjava.c
     - Removed the SWITCH LOOP from hb_compGenCCompact()

   * source/compiler/genobj32.c
     - Removed the SWITCH LOOP from hb_compGenCCompact()
2000-04-21 03:22:00 +00:00

206 lines
5.9 KiB
C

/*
* $Id$
*/
/*
* Harbour Project source code:
* Compiler Java source generation
*
* Copyright 1999 Matteo Baccan <baccan@isanet.it>
* Based on a work of Eddie Runia <eddie@runia.com>
* 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/).
*
*/
#include "hbcomp.h"
#define SYM_NOLINK 0 /* Symbol does not have to be linked */
#define SYM_FUNC 1 /* Defined function */
#define SYM_EXTERN 2 /* Previously defined function */
static void hb_fputc( BYTE b );
static void hb_fputs( char * szName );
static FILE * s_yyc;
static int s_nChar = 0;
void hb_compGenJava( PHB_FNAME pFileName )
{
char szFileName[ _POSIX_PATH_MAX ];
PFUNCTION pFunc /*= hb_comp_functions.pFirst */;
PCOMSYMBOL pSym = hb_comp_symbols.pFirst;
USHORT wLen, wVar;
ULONG lPCodePos;
LONG lSymbols;
ULONG ulCodeLength;
FILE * s_yyc; /* file handle for C output */
if( ! pFileName->szExtension )
pFileName->szExtension = ".java";
hb_fsFNameMerge( szFileName, pFileName );
s_yyc = fopen( szFileName, "wb" );
if( ! s_yyc )
{
hb_compGenError( hb_comp_szErrors, 'E', HB_COMP_ERR_CREATE_OUTPUT, szFileName, NULL );
return;
}
if( ! hb_comp_bQuiet )
{
printf( "Generating Java source output to \'%s\'... ", szFileName );
fflush( stdout );
}
s_nChar = 0;
fprintf( s_yyc, "/*\n * Harbour Compiler, %d.%d%s (Build %d) (%04d.%02d.%02d)\n",
HB_VER_MAJOR, HB_VER_MINOR, HB_VER_REVISION, HB_VER_BUILD, HB_VER_YEAR, HB_VER_MONTH, HB_VER_DAY );
fprintf( s_yyc, " * Generated JAVA source code\n */\n\n" );
fprintf( s_yyc, "public class %s\n", pFileName->szName );
fprintf( s_yyc, "{\n" );
fprintf( s_yyc, " public static int[] pCode =\n" );
fprintf( s_yyc, " {\n" );
fprintf( s_yyc, " " );
/* writes the symbol table */
lSymbols = 0; /* Count number of symbols */
while( pSym )
{
lSymbols++;
pSym = pSym->pNext;
}
hb_fputc( ( BYTE ) ( ( lSymbols ) & 255 ) ); /* Write number symbols */
hb_fputc( ( BYTE ) ( ( lSymbols >> 8 ) & 255 ) );
hb_fputc( ( BYTE ) ( ( lSymbols >> 16 ) & 255 ) );
hb_fputc( ( BYTE ) ( ( lSymbols >> 24 ) & 255 ) );
pSym = hb_comp_symbols.pFirst;
while( pSym )
{
hb_fputs( pSym->szName );
hb_fputc( 0 );
if( pSym->cScope != HB_FS_MESSAGE )
hb_fputc( pSym->cScope );
else
hb_fputc( 0 );
/* specify the function address if it is a defined function or a
external called function */
if( hb_compFunctionFind( pSym->szName ) ) /* is it a defined function ? */
{
hb_fputc( SYM_FUNC );
}
else
{
if( hb_compFunCallFind( pSym->szName ) )
{
hb_fputc( SYM_EXTERN );
}
else
{
hb_fputc( SYM_NOLINK );
}
}
pSym = pSym->pNext;
}
pFunc = hb_comp_functions.pFirst;
if( ! hb_comp_bStartProc )
pFunc = pFunc->pNext;
lSymbols = 0; /* Count number of symbols */
while( pFunc )
{
lSymbols++;
pFunc = pFunc->pNext;
}
hb_fputc( ( BYTE ) ( ( lSymbols ) & 255 ) ); /* Write number symbols */
hb_fputc( ( BYTE ) ( ( lSymbols >> 8 ) & 255 ) );
hb_fputc( ( BYTE ) ( ( lSymbols >> 16 ) & 255 ) );
hb_fputc( ( BYTE ) ( ( lSymbols >> 24 ) & 255 ) );
/* Generate functions data
*/
pFunc = hb_comp_functions.pFirst;
if( ! hb_comp_bStartProc )
pFunc = pFunc->pNext; /* No implicit starting procedure */
while( pFunc )
{
hb_fputs( pFunc->szName );
hb_fputc( 0 );
ulCodeLength = pFunc->lPCodePos;
hb_fputc( ( BYTE ) ( ( ulCodeLength ) & 255 ) ); /* Write size */
hb_fputc( ( BYTE ) ( ( ulCodeLength >> 8 ) & 255 ) );
hb_fputc( ( BYTE ) ( ( ulCodeLength >> 16 ) & 255 ) );
hb_fputc( ( BYTE ) ( ( ulCodeLength >> 24 ) & 255 ) );
/* printf( "Creating output for %s\n", pFunc->szName ); */
lPCodePos = 0;
while( lPCodePos < pFunc->lPCodePos )
hb_fputc( pFunc->pCode[ lPCodePos++ ] );
pFunc = pFunc->pNext;
}
fprintf( s_yyc, "\n };\n\n" );
fprintf( s_yyc, " static public void main( String argv[] )\n" );
fprintf( s_yyc, " {\n" );
fprintf( s_yyc, " Harbour.Run( %s.pCode ); \n", pFileName->szName );
fprintf( s_yyc, " }\n\n" );
fprintf( s_yyc, "}\n" );
fclose( s_yyc );
if( ! hb_comp_bQuiet )
printf( "Done.\n" );
}
static void hb_fputc( BYTE b )
{
if( ++s_nChar > 1 )
fprintf( s_yyc, ", " );
if( s_nChar == 9 )
{
fprintf( s_yyc, "\n " );
s_nChar = 1;
}
fprintf( s_yyc, "0x%02X", ( int ) b );
}
static void hb_fputs( char * szName )
{
unsigned int nPos = 0;
while( nPos < strlen( szName ) )
hb_fputc( szName[ nPos++ ] );
}