⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cprag370.c

📁 Open Watcom 的 C 编译器源代码
💻 C
字号:
/****************************************************************************
*
*                            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 "cvars.h"
#include "ctokens.h"
#include "pragdefn.h"
#include "pdefn2.h"


extern  void    NextToken();            /* cscan */
extern  void    SetCurrInfo();
extern  char    *CMemAlloc();           /* cmemmgr */
extern  unsigned long SizeOfArg();      /* csizeof */
extern  void    PragObjNameInfo();
extern  void    PragInit();
extern  void    MustRecog();
extern  void    PragEnding();
extern  int     PragRecog();
extern  void    PragCurrAlias();
extern  hw_reg_set PragRegList();
extern  void    PragManyRegSets(void);
extern  struct aux_entry *AuxLookup();  /* caux.c */

static  int     Offset;

hw_reg_set PragRegName( char * buffer )
    {
        hw_reg_set      name;

        buffer = buffer; /* don't need it. */
        HW_CAsgn( name, HW_EMPTY );
        if( CurToken != T_CONSTANT || Constant > 15 ) return( name );
        return( RegBits[ Constant ] );
    }


void PragmaInit()
    {
        Offset = 0;
        PragInit();
    }


static call_class PragLinkage()
{
    call_class  linkage;

    linkage = 0;
    if( PragRecog( "os" ) || PragRecog( "OS" ) ) {
        linkage = LINKAGE_OS;
    } else if( PragRecog( "osfunc" ) ) {
        linkage = LINKAGE_OSFUNC;
    } else if( PragRecog( "osentry" ) ) {
        linkage = LINKAGE_OSENTRY;
    } else if( PragRecog( "clink" ) ) {
        linkage = LINKAGE_CLINK;
    }
    return( linkage );
}


static void PragInitCurrInfo( call_class linkage )
{
    *CurrInfo = *CurrAlias;
    if( linkage != 0 ) {
        if( linkage == LINKAGE_CLINK ) {
            CurrInfo->linkage = &DefaultLinkage;
        } else {
            CurrInfo->linkage = &OSLinkage;
        }
        CurrInfo->class &= ~LINKAGES;
        CurrInfo->class |= linkage;
    }
}


static int GetAliasInfo()
    {
        call_class      linkage;
        auto char buff[256];

        CurrAlias = &DefaultInfo;
        if( CurToken != T_LEFT_PAREN ) return( 1 );
        NextToken();
        if( CurToken != T_ID ) return( 0 );
        PragCurrAlias();
        strcpy( buff, Buffer );
        NextToken();
        if( CurToken == T_RIGHT_PAREN ) {
            NextToken();
            return( 1 );
        } else if( CurToken == T_COMMA ) {
            NextToken();
            CreateAux( buff );
            linkage = PragLinkage();
            if( linkage == LINKAGE_OS ) {
                linkage |= PARMS_BY_ADDRESS;
            }
            if( CurToken == T_RIGHT_PAREN ) {
                NextToken();
                PragInitCurrInfo( linkage );
            }
            PragEnding();
            return( 0 ); /* process no more! */
        }
        return( 0 ); /* process no more! */
    }


void PragAux()
    {
        call_class      linkage;
        struct {
            unsigned f_equal  : 1;
            unsigned f_parm   : 1;
            unsigned f_linkage: 1;
            unsigned f_value  : 1;
            unsigned f_modify : 1;
            unsigned f_offset : 1;
        } have;


        if( CheckForOrigin() ) return;
        if( !GetAliasInfo() ) return;
        CurrEntry = NULL;
        if( CurToken != T_ID ) return;
        linkage = PragLinkage();
        SetCurrInfo();
        NextToken();
        PragInitCurrInfo( linkage );
        have.f_offset = 0;
        have.f_equal  = 0;
        have.f_parm   = 0;
        have.f_linkage= 0;
        have.f_value  = 0;
        have.f_modify = 0;
        for( ;; ) {
            if( !have.f_equal && CurToken == T_EQUAL ) {
                // GetByteSeq();
                have.f_equal = 1;
            } else if( !have.f_parm && PragRecog( "parm" ) ) {
                GetParmInfo();
                have.f_parm = 1;
            } else if( !have.f_linkage && PragRecog( "registers" ) ) {
                GetLinkInfo();
                have.f_linkage = 1;
            } else if( !have.f_value && PragRecog( "value" ) ) {
                GetRetInfo();
                have.f_value = 1;
            } else if( !have.f_modify && PragRecog( "modify" ) ) {
                GetSaveInfo();
                have.f_modify = 1;
            } else if( !have.f_offset && PragRecog( "offset" ) ) {
                GetOffsetInfo();
                have.f_offset = 1;
            } else {
                break;
            }
        }
        PragEnding();
    }

local int TryForReg( hw_reg_set *field, char *name )
    {
        if( HW_CEqual( *field, HW_EMPTY ) && PragRecog( name ) ) {
            *field = PragRegName("");
            NextToken();
            return( 1 );
        }
        return( 0 );
    }


local void NotEmpty( hw_reg_set *link, hw_reg_set *curr )
    {
        if( HW_CEqual( *link, HW_EMPTY ) ) {
            HW_Asgn( *link, *curr );
        }
    }


local void GetLinkInfo()
    {
        linkage_regs    *link;

        link = (linkage_regs *)CMemAlloc( sizeof( *link ) );
        memset( link, 0, sizeof( *link ) ); /* assume equivalent to HW_EMPTY */
        for( ;; ) {
            if( TryForReg( &link->gp, "gp" ) ) continue;
            if( TryForReg( &link->sp, "sp" ) ) continue;
            if( TryForReg( &link->ln, "ln" ) ) continue;
            if( TryForReg( &link->ra, "ra" ) ) continue;
            if( TryForReg( &link->pr, "pr" )) continue;
            if( TryForReg( &link->sa, "sa" ) ) continue;
            break;
        }
        NotEmpty( &link->gp, &CurrInfo->linkage->gp );
        NotEmpty( &link->sp, &CurrInfo->linkage->sp );
        NotEmpty( &link->ln, &CurrInfo->linkage->ln );
        NotEmpty( &link->ra, &CurrInfo->linkage->ra );
        NotEmpty( &link->pr, &CurrInfo->linkage->pr);
        NotEmpty( &link->sa, &CurrInfo->linkage->sa );
        CurrInfo->linkage = link;
    }


local void GetParmInfo()
    {
        if( PragSet() != T_NULL ) {
            PragManyRegSets();
        }
    }


local int CheckForOrigin()
    {
        if( !PragRecog( "origin" ) ) return( FALSE );
        if( CurToken != T_CONSTANT ) return( FALSE );
        Offset = Constant;
        NextToken();
        return( TRUE );
    }


local void GetOffsetInfo()
    {
        if( CurToken != T_CONSTANT ) return;
        CurrEntry->offset = Offset;
        Offset += Constant;
        NextToken();
    }


local void GetSaveInfo()
    {
        hw_reg_set      reg;

        reg = PragRegList();
        HW_TurnOff( CurrInfo->save, reg );
    }


local void GetRetInfo()
    {
        CurrInfo->returns = PragRegList();
    }

⌨️ 快捷键说明

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