Changeset 292 in dev for trunk/abdev/BasicCompiler_Common


Ignore:
Timestamp:
Aug 22, 2007, 3:46:23 AM (17 years ago)
Author:
dai_9181
Message:
 
Location:
trunk/abdev/BasicCompiler_Common
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • trunk/abdev/BasicCompiler_Common/NumOpe_GetType.cpp

    r290 r292  
    301301}
    302302
    303 bool GetTermType( const char *term, Type &resultType, bool &isLiteral, bool *pIsClassName ){
     303bool GetTermType( const char *term, Type &resultType, bool &isLiteral, bool *pIsClassName )
     304{
     305    if( (string)term=="a[1]")
     306    {
     307        int test=0;
     308    }
    304309    char parameter[VN_SIZE];
    305310
     
    390395                {
    391396                    // 型パラメータだったとき
     397
     398                    int ptrLevel = PTR_LEVEL( resultType.GetBasicType() );
     399
    392400                    if( leftType.HasActualGenericType() )
    393401                    {
     
    399407                        // TODO: ベースオブジェクト(指定されていないときはObjectクラス)にセットする
    400408                        resultType.SetBasicType( DEF_OBJECT );
     409                    }
     410
     411                    for( int i=0; i<ptrLevel; i++ )
     412                    {
     413                        resultType.PtrLevelUp();
    401414                    }
    402415                }
     
    513526    GetArrayElement(termFull,VarName,ArrayElements);
    514527    if(ArrayElements[0]){
    515         GetVarType(VarName,resultType,false);
    516         if( resultType.IsObject() ){
    517             if( !GetReturnTypeOfIndexerGetterProc( resultType.GetClass(),resultType) ){
     528        Type classType;
     529        GetVarType(VarName,classType,false);
     530        if( classType.IsObject() ){
     531            if( !GetReturnTypeOfIndexerGetterProc( classType, resultType ) ){
    518532                SetError(1,NULL,cp);
    519533                return false;
  • trunk/abdev/BasicCompiler_Common/Subroutine.cpp

    r290 r292  
    228228
    229229        resultType = pUserProc->ReturnType();
     230
     231        Type leftType;
     232        GetVarType( ObjectName, leftType, false );
     233
     234        /////////////////////////////////////////////////////////
     235        // ☆★☆ ジェネリクスサポート ☆★☆
     236
     237        if( resultType.IsTypeParameter() )
     238        {
     239            // 型パラメータだったとき
     240
     241            int ptrLevel = PTR_LEVEL( resultType.GetBasicType() );
     242
     243            if( leftType.HasActualGenericType() )
     244            {
     245                // TODO: GetDummyActualGenericTypeを適切な形に実装し直す
     246                resultType = leftType.GetDummyActualGenericType();
     247            }
     248            else
     249            {
     250                // TODO: ベースオブジェクト(指定されていないときはObjectクラス)にセットする
     251                resultType.SetBasicType( DEF_OBJECT );
     252            }
     253
     254            for( int i=0; i<ptrLevel; i++ )
     255            {
     256                resultType.PtrLevelUp();
     257            }
     258        }
     259
     260        //
     261        /////////////////////////////////////////////////////////
    230262    }
    231263
     
    274306
    275307//インデクサ(getter)の戻り値を取得
    276 bool GetReturnTypeOfIndexerGetterProc( const CClass &objClass, Type &resultType ){
     308bool GetReturnTypeOfIndexerGetterProc( const Type &classType, Type &resultType )
     309{
    277310    vector<const UserProc *> subs;
    278     objClass.GetMethods().Enum( CALC_ARRAY_GET, subs );
     311    classType.GetClass().GetMethods().Enum( CALC_ARRAY_GET, subs );
    279312    if( subs.size() == 0 ){
    280313        return false;
     
    282315
    283316    resultType = subs[0]->ReturnType();
     317
     318
     319    /////////////////////////////////////////////////////////
     320    // ☆★☆ ジェネリクスサポート ☆★☆
     321
     322    if( resultType.IsTypeParameter() )
     323    {
     324        // 型パラメータだったとき
     325
     326        int ptrLevel = PTR_LEVEL( resultType.GetBasicType() );
     327
     328        if( classType.HasActualGenericType() )
     329        {
     330            // TODO: GetDummyActualGenericTypeを適切な形に実装し直す
     331            resultType = classType.GetDummyActualGenericType();
     332        }
     333        else
     334        {
     335            // TODO: ベースオブジェクト(指定されていないときはObjectクラス)にセットする
     336            resultType.SetBasicType( DEF_OBJECT );
     337        }
     338
     339        for( int i=0; i<ptrLevel; i++ )
     340        {
     341            resultType.PtrLevelUp();
     342        }
     343    }
     344
     345    //
     346    /////////////////////////////////////////////////////////
    284347
    285348    return true;
  • trunk/abdev/BasicCompiler_Common/VariableOpe.cpp

    r290 r292  
    480480    {
    481481        // 型パラメータだったとき
     482
     483        int ptrLevel = PTR_LEVEL( resultType.GetBasicType() );
     484
    482485        if( classType.HasActualGenericType() )
    483486        {
     
    489492            // TODO: ベースオブジェクト(指定されていないときはObjectクラス)にセットする
    490493            resultType.SetBasicType( DEF_OBJECT );
     494        }
     495
     496        for( int i=0; i<ptrLevel; i++ )
     497        {
     498            resultType.PtrLevelUp();
    491499        }
    492500    }
  • trunk/abdev/BasicCompiler_Common/common.h

    r290 r292  
    356356bool CallPropertyMethod( const char *variable, const char *rightSide, Type &resultType);
    357357bool GetReturnTypeOfPropertyMethod( const char *variable, const char *rightSide, Type &resultType );
    358 bool GetReturnTypeOfIndexerGetterProc( const CClass &objClass, Type &resultType );
     358bool GetReturnTypeOfIndexerGetterProc( const Type &classType, Type &resultType );
    359359int AddProcPtrInfo( const string &typeExpression, int nowLine );
    360360bool IsNeedProcCompile();
  • trunk/abdev/BasicCompiler_Common/src/Type.cpp

    r290 r292  
    408408bool Type::IsTypeParameter() const
    409409{
    410     return ( basicType == DEF_TYPE_PARAMETER );
     410    return ( NATURAL_TYPE(basicType) == DEF_TYPE_PARAMETER );
    411411}
    412412bool Type::IsObjectClass() const
Note: See TracChangeset for help on using the changeset viewer.