Changes in / [5684736:9151fcb]


Ignore:
Location:
src
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/AST/Convert.cpp

    r5684736 r9151fcb  
    735735                expr->var = get<DeclarationWithType>().accept1(node->var);
    736736                Type * type = expr->var->get_type()->clone();
     737                if(FunctionType * ft = dynamic_cast<FunctionType*>(type)) {
     738                        if(node->result.as<ast::PointerType>()) {
     739                                type = new PointerType({}, ft);
     740                        }
     741                }
     742
    737743                type->set_lvalue( true );
    738                 expr->set_result( type );
     744                expr->result = type ;
    739745                this->node = expr;
    740746                return nullptr;
     
    782788                        assert (!rslt->isType);
    783789                }
    784                 if (node->type) {
     790                else {
     791                        assert(node->type);
    785792                        rslt = new SizeofExpr(
    786793                                get<Type>().accept1(node->type)
     
    803810                        assert (!rslt->isType);
    804811                }
    805                 if (node->type) {
     812                else {
     813                        assert(node->type);
    806814                        rslt = new AlignofExpr(
    807815                                get<Type>().accept1(node->type)
     
    21492157                );
    21502158
    2151                 visitBaseExpr( old,
     2159                visitBaseExpr_SkipResultType( old,
    21522160                        expr
    21532161                );
     
    21552163                expr->var = GET_ACCEPT_1(var, DeclWithType);
    21562164                expr->result = expr->var->get_type();
     2165                if(const ast::FunctionType * ft = expr->result.as<ast::FunctionType>()) {
     2166                        if(dynamic_cast<PointerType *>(old->result)) {
     2167                                expr->result = new ast::PointerType(ft);
     2168                        }
     2169                }
    21572170                add_qualifiers( expr->result, ast::CV::Lvalue );
    21582171                this->node = expr;
  • src/GenPoly/Lvalue.cc

    r5684736 r9151fcb  
    196196                                unsigned int i = 0;
    197197                                const unsigned int end = ftype->parameters.size();
     198
     199                                /// The for loop may eagerly dereference the iterators and fail on empty lists
     200                                if(i == end) { return appExpr; }
    198201                                for ( auto p : unsafe_group_iterate( appExpr->args, ftype->parameters ) ) {
    199202                                        if (i == end) break;
Note: See TracChangeset for help on using the changeset viewer.