rtngen.c

来自「开放源码的编译器open watcom 1.6.0版的源代码」· C语言 代码 · 共 220 行

C
220
字号
/****************************************************************************
*
*                            Open Watcom Project
*
*    Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
*
*  ========================================================================
*
*    This file contains Original Code and/or Modifications of Original
*    Code as defined in and that are subject to the Sybase Open Watcom
*    Public License version 1.0 (the 'License'). You may not use this file
*    except in compliance with the License. BY USING THIS FILE YOU AGREE TO
*    ALL TERMS AND CONDITIONS OF THE LICENSE. A copy of the License is
*    provided with the Original Code and Modifications, and is also
*    available at www.sybase.com/developer/opensource.
*
*    The Original Code and all software distributed under the License are
*    distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
*    EXPRESS OR IMPLIED, AND SYBASE AND ALL CONTRIBUTORS HEREBY DISCLAIM
*    ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF
*    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
*    NON-INFRINGEMENT. Please see the License for the specific language
*    governing rights and limitations under the License.
*
*  ========================================================================
*
* Description:  WHEN YOU FIGURE OUT WHAT THIS FILE DOES, PLEASE
*               DESCRIBE IT HERE!
*
****************************************************************************/


#include "plusplus.h"
#include "errdefns.h"
#include "cgfront.h"
#include "carve.h"
#include "ring.h"
#include "class.h"
#include "initdefs.h"
#include "pcheader.h"
#include "rtngen.h"

typedef struct routine_gen RTN_GEN;
struct routine_gen {
    RTN_GEN             *next;
    unsigned            index;
    void                *parm;
};

#define BLOCK_RTN_GEN           16
static carve_t carveRTN_GEN;

// scheduled routines with their parm types
static RTN_GEN *useSYMBOL;
static RTN_GEN *useTYPE;

static void (*execSYMBOL[])( SYMBOL ) = {
#define RTN_GEN_SYMBOL( name )  RtnGenCallBack##name,
#include "rtnglist.h"
};
static void (*execTYPE[])( TYPE ) = {
#define RTN_GEN_TYPE( name )    RtnGenCallBack##name,
#include "rtnglist.h"
};

static RTN_GEN *findGenRoutine( RTN_GEN **head, unsigned index, void *parm )
{
    RTN_GEN *r;

#ifndef NDEBUG
    if( parm == NULL ) {
        CFatal( "rtn gen parm must be non-NULL" );
    }
#endif
    for( r = *head; r != NULL; r = r->next ) {
        if( index == r->index && parm == r->parm ) {
            return( r );
        }
    }
    return( NULL );
}

static void addGenRoutine( RTN_GEN **head, unsigned index, void *parm )
{
    RTN_GEN *r;

    r = StackCarveAlloc( carveRTN_GEN, head );
    r->index = index;
    r->parm = parm;
}

void RtnGenAddSymbol( RTNGEN_SYMBOL index, SYMBOL parm )
/******************************************************/
{
    RTN_GEN *r;

    r = findGenRoutine( &useSYMBOL, index, parm );
    if( r == NULL ) {
        addGenRoutine( &useSYMBOL, index, parm );
    }
}

void RtnGenAddType( RTNGEN_TYPE index, TYPE parm )
/************************************************/
{
    RTN_GEN *r;

    r = findGenRoutine( &useTYPE, index, parm );
    if( r == NULL ) {
        addGenRoutine( &useTYPE, index, parm );
    }
}

void RtnGenerate( void )
/**********************/
{
    RTN_GEN *c;

    ClassDefineRefdDefaults();
    ScopeEmitIndexMappings();
    while( useSYMBOL != NULL ) {
        c = useSYMBOL;
        useSYMBOL = c->next;
        (*execSYMBOL[ c->index ])( c->parm );
        CarveFree( carveRTN_GEN, c );
    }
    while( useTYPE != NULL ) {
        c = useTYPE;
        useTYPE = c->next;
        (*execTYPE[ c->index ])( c->parm );
        CarveFree( carveRTN_GEN, c );
    }
    SetCurrScope(GetFileScope());
}


static void rtnGenInit(         // INITIALIZE FOR ROUTINE GENERATION
    INITFINI* defn )            // - definition
{
    defn = defn;
    useSYMBOL = NULL;
    useTYPE = NULL;
    carveRTN_GEN = CarveCreate( sizeof( RTN_GEN ), BLOCK_RTN_GEN );
}


static void rtnGenFini(         // COMPLETE ROUTINE GENERATION
    INITFINI* defn )            // - definition
{
    defn = defn;
    CarveDestroy( carveRTN_GEN );
}


INITDEFN( rtn_gen, rtnGenInit, rtnGenFini )

pch_status PCHReadGenerators( void )
{
    unsigned index;
    SYMBOL read_symbol;
    TYPE read_type;

    carveRTN_GEN = CarveRestart( carveRTN_GEN );
    useSYMBOL = NULL;
    useTYPE = NULL;
    for(;;) {
        PCHRead( &read_symbol, sizeof( read_symbol ) );
        read_symbol = SymbolMapIndex( read_symbol );
        if( read_symbol == NULL ) break;
        PCHRead( &index, sizeof( index ) );
        addGenRoutine( &useSYMBOL, index, read_symbol );
    }
    for(;;) {
        PCHRead( &read_type, sizeof( read_type ) );
        read_type = TypeMapIndex( read_type );
        if( read_type == NULL ) break;
        PCHRead( &index, sizeof( index ) );
        addGenRoutine( &useTYPE, index, read_type );
    }
    return( PCHCB_OK );
}

pch_status PCHWriteGenerators( void )
{
    unsigned index;
    SYMBOL write_symbol;
    TYPE write_type;
    RTN_GEN *c;

    for( c = useSYMBOL; c != NULL; c = c->next ) {
        write_symbol = SymbolGetIndex( c->parm );
        PCHWrite( &write_symbol, sizeof( write_symbol ) );
        index = c->index;
        PCHWrite( &index, sizeof( index ) );
    }
    write_symbol = SymbolGetIndex( NULL );
    PCHWrite( &write_symbol, sizeof( write_symbol ) );
    for( c = useTYPE; c != NULL; c = c->next ) {
        write_type = TypeGetIndex( c->parm );
        PCHWrite( &write_type, sizeof( write_type ) );
        index = c->index;
        PCHWrite( &index, sizeof( index ) );
    }
    write_type = TypeGetIndex( NULL );
    PCHWrite( &write_type, sizeof( write_type ) );
    return( PCHCB_OK );
}

pch_status PCHInitGenerators( boolean writing )
{
    writing = writing;
    return( PCHCB_OK );
}

pch_status PCHFiniGenerators( boolean writing )
{
    writing = writing;
    return( PCHCB_OK );
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?