亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? compile.c

?? nVidia開發的圖形語言 Cg
?? C
?? 第 1 頁 / 共 5 頁
字號:
 * ExpandIncDecExpr() - Expand increment/decrement operations.
 *
 * Pre increment/decrement is the simple case:
 *
 *   ++A -> A += 1
 *
 * Post increment/decrement is a little more tricky:
 *
 *   If A is simple (i.e. not an array reference):
 *
 *     A++ -> tmp = A, A += 1, tmp
 *
 *   If A is an array reference:
 *
 *     A[i1]...[iN]++ ->
 *       tmpi1 = i1, ..., tmpiN = iN, tmpv = A[tmpi1]...[tmpiN],
 *       A[tmpi1]...[tmpiN] += 1, tmpv
 *
 */

expr *ExpandIncDecExpr(expr *fExpr, void *arg1, int arg2)
{
    int pre = 0;
    int newop = -1;
    expr *oneExpr;
    expr *result = NULL;

    if (fExpr->common.kind == UNARY_N) {
        switch (fExpr->un.op) {
        case PREDEC_OP:
            pre = 1;
        case POSTDEC_OP:
            newop = ASSIGNMINUS_OP;
            break;
        case PREINC_OP:
            pre = 1;
        case POSTINC_OP:
            newop = ASSIGNPLUS_OP;
            break;
        }
    }

    if (newop == -1)
        return fExpr;

    oneExpr = (expr *) NewIConstNode(ICONST_OP, 1, TYPE_BASE_INT); 
    
    if (pre)
        result = (expr *) NewBinopNode(newop, fExpr->un.arg, oneExpr);
    else {
        expr *idxAssigns = IsArrayIndex(fExpr->un.arg)
            ? PutIndexEpxrsInTemps(fExpr->un.arg) : NULL;
        expr *tmp = (expr *) NewTmp(fExpr->un.arg);
        expr *tmpAssign = NewSimpleAssignment(Cg->pLastSourceLoc, tmp, fExpr->un.arg, 0);
        expr *incdec = (expr *) NewBinopNode(newop, DupNode(fExpr->un.arg), oneExpr);
        expr *rval = DupNode(tmp);
        result = (expr *) NewBinopNode(COMMA_OP, incdec, rval);
        result = (expr *) NewBinopNode(COMMA_OP, tmpAssign, result);
        if (idxAssigns)
            result = (expr *) NewBinopNode(COMMA_OP, idxAssigns, result);
    }

    return result;

} // ExpandIncDecExpr

///////////////////////////////////////////////////////////////////////////////////////////////
/////////////////////////// Expand Compound Assignment Expressions ////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////

/*
 * ExpandCompoundAssignmentExpr() - Transform compound assignments
 * into simple assignments.
 *
 * If A is simple (i.e. not an array reference):
 *
 *   A op= B -> A = A op B
 *
 * If A is an array reference:
 *
 *   A[e1]...[eN] op= B ->
 *     tmp1 = e1, ..., tmpN = eN, A[tmp1]...[tmpN] = A[tmp1]...[tmpN] op B
 *  
 */

expr *ExpandCompoundAssignmentExpr(expr *fExpr, void *arg1, int arg2)
{
    int newop = -1;
    int opname = 0;
    int intOnly = 0;
    expr *lexpr, *rExpr;
    expr *result = NULL;
    expr *idxAssigns = NULL;

    if (fExpr->common.kind == BINARY_N) {
        switch (fExpr->bin.op) {
        case ASSIGNMINUS_OP:
            newop = SUB_OP;
            opname = '-';
            break;
        case ASSIGNMOD_OP:
            newop = MOD_OP;
            opname = '%';
            intOnly = 1;
            break;
        case ASSIGNPLUS_OP:
            newop = ADD_OP;
            opname = '+';
            break;
        case ASSIGNSLASH_OP:
            newop = DIV_OP;
            opname = '/';
            break;
        case ASSIGNSTAR_OP:
            newop = MUL_OP;
            opname = '*';
            break;
        }
    }

    if (newop == -1)
        return fExpr;

    lexpr = fExpr->bin.left;
    rExpr = fExpr->bin.right;

    if (IsArrayIndex(lexpr))
        idxAssigns = PutIndexEpxrsInTemps(lexpr);
    
    result = NewBinaryOperator(Cg->pLastSourceLoc, newop, opname, lexpr, rExpr, intOnly);
    result = NewSimpleAssignment(Cg->pLastSourceLoc, DupNode(lexpr), result, 0);
    if (idxAssigns)
        result = (expr *) NewBinopNode(COMMA_OP, idxAssigns, result);

    return result;
} // ExpandCompoundAssignmentExpr

///////////////////////////////////////////////////////////////////////////////////////////////
///////////////////////////// Flatten Chained Assignment Statements ///////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////

typedef struct MData_rec {
    Scope *scope;
    int numtemps;
    StmtList statements;
} MData;

/*
 * IsConstant()
 *
 */

int IsConstant(expr *fExpr)
{
    switch (fExpr->common.kind) {
    case CONST_N:
        return 1;
    default:
        break;
    }
    return 0;
} // IsConstant

/*
 * IsVariable()
 *
 */

int IsVariable(expr *fExpr)
{
    switch (fExpr->common.kind) {
    case SYMB_N:
        return 1;
    default:
        break;
    }
    return 0;
} // IsVariable

/*
 * IsCompileTimeAddress()
 *
 */

int IsCompileTimeAddress(expr *fExpr)
{
    if (fExpr->common.IsLValue) {
        switch (fExpr->common.kind) {
        case SYMB_N:
            return 1;
        case BINARY_N:
            switch (fExpr->bin.op) {
            case MEMBER_SELECTOR_OP:
                return IsCompileTimeAddress(fExpr->bin.left);
            case ARRAY_INDEX_OP:
                if (IsCompileTimeAddress(fExpr->bin.left)) {
                    if (IsConstant(fExpr->bin.right)) {
                        return 1;
                    }
                }
                break;
            default:
                break;
            }
            break;
        default:
            break;
        }
    }
    return 0;
} // IsCompileTimeAddress

/*
 * GetConstIndex()
 *
 */

int GetConstIndex(expr *fExpr)
{
    switch (fExpr->common.kind) {
    case CONST_N:
        switch (fExpr->co.op) {
        case ICONST_OP:
        case BCONST_OP:
            return fExpr->co.val[0].i;
            break;
        case FCONST_OP:
        case HCONST_OP:
        case XCONST_OP:
            return (int) fExpr->co.val[0].f;
            break;
        default:
            break;
        }
        break;
    default:
        break;
    }
    return 0;
} // GetConstIndex

///////////////////////////////////////////////////////////////////////////////////////////////
////////////////////// Flatten comma expressions into statement lists /////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////

static int IsComma(const expr *fExpr)
{
    return fExpr->common.kind == BINARY_N && fExpr->bin.op == COMMA_OP;
} // IsComma

/*
 * FlattenCommasExpr()
 *
 * op (a, b) -> a, (op b)
 * (a, b) op c -> a, (b op c)
 * A[e1]...[eN] = (b, c) -> (tmp1 = e1), ..., (tmpN = eN), b, A[tmp1]...[tmpN] = c
 * a = (b, c) -> b, a = c
 * a op (b, c) -> (tmpa = a), b, (tmpa op c)
 * (a, b) ? c : d -> a, (b ? c : d)
 * a ? (b, c) : d -> (tmpa = a), b, (tmpa ? c : d)
 * a ? b : (c, d) -> (tmpa = a), (tmpb = b), c, (tmpa ? tmpb : d)
 */

static expr *FlattenCommasExpr(expr *fExpr, void *arg1, int arg2)
{
    switch (fExpr->common.kind) {
    case UNARY_N:
        if (IsComma(fExpr->un.arg)) {
            expr *comma = fExpr->un.arg;
            fExpr->un.arg = comma->bin.right;
            fExpr = (expr *) NewBinopNode(COMMA_OP, comma->bin.left, fExpr);
        }
        break;
    case BINARY_N: {
        binary *bin = &fExpr->bin;
        if (IsComma(bin->left)) {
            expr *comma = bin->left;
            bin->left = comma->bin.right;
            fExpr = (expr *) NewBinopNode(COMMA_OP, comma->bin.left, (expr *) bin);
        }
        if (bin->right && IsComma(bin->right)) {
            // Assignments/lvalues are special
            if (bin->op == ASSIGN_OP || bin->op == ASSIGN_V_OP) {
                expr *idxAssigns = IsArrayIndex(bin->left)
                    ? PutIndexEpxrsInTemps(bin->left) : NULL;
                fExpr = (expr *) NewBinopNode(COMMA_OP, bin->right->bin.left,
                                              fExpr);
                bin->right = bin->right->bin.right;
                if (idxAssigns)
                    fExpr = (expr *) NewBinopNode(COMMA_OP, idxAssigns, fExpr);
            } else if (bin->op != COMMA_OP) {
                // no need to lift comma ops above a comma op
                expr *comma = bin->right;
                expr *tmp = (expr *) NewTmp(bin->left);
                expr *assign = NewSimpleAssignment(Cg->pLastSourceLoc, tmp, bin->left, 0);
                bin->left = DupNode(tmp);
                bin->right = comma->bin.right;
                fExpr = (expr *) NewBinopNode(COMMA_OP, comma->bin.left, (expr *) bin);
                fExpr = (expr *) NewBinopNode(COMMA_OP, assign, fExpr);
            }
        }
        break;
    }
    case TRINARY_N: {
        trinary *tri = &fExpr->tri;
        if (IsComma(tri->arg1)) {
            expr *comma = tri->arg1;
            tri->arg1 = comma->bin.right;
            fExpr = (expr *) NewBinopNode(COMMA_OP, comma->bin.left, (expr *) tri);
        }
        if (IsComma(tri->arg2)) {
            expr *comma = tri->arg2;
            expr *tmp = (expr *) NewTmp(tri->arg1);
            expr *assign = NewSimpleAssignment(Cg->pLastSourceLoc, tmp, tri->arg1, 0);
            tri->arg1 = DupNode(tmp);
            tri->arg2 = comma->bin.right;
            fExpr = (expr *) NewBinopNode(COMMA_OP, comma->bin.left, (expr *) tri);
            fExpr = (expr *) NewBinopNode(COMMA_OP, assign, fExpr);
        }
        if (IsComma(tri->arg3)) {
            expr *comma = tri->arg3;
            expr *tmp1 = (expr *) NewTmp(tri->arg1);
            expr *tmp2 = (expr *) NewTmp(tri->arg2);
            expr *assign1 = NewSimpleAssignment(Cg->pLastSourceLoc, tmp1, tri->arg1, 0);
            expr *assign2 = NewSimpleAssignment(Cg->pLastSourceLoc, tmp2, tri->arg2, 0);
            tri->arg1 = DupNode(tmp1);
            tri->arg2 = DupNode(tmp2);
            tri->arg3 = comma->bin.right;
            fExpr = (expr *) NewBinopNode(COMMA_OP, comma->bin.left, (expr *) tri);
            fExpr = (expr *) NewBinopNode(COMMA_OP, assign2, fExpr);
            fExpr = (expr *) NewBinopNode(COMMA_OP, assign1, fExpr);
        }
        break;
    }
    }

    return fExpr;
} // FlattenCommasExpr

/*
 * LinearizeCommasExpr() - Gets rid of all top-level comma expressions
 * by pulling them out into an expression list (returned through
 * arg1).
 *
 */

static expr *LinearizeCommasExpr(expr *fExpr, void *arg1, int arg2)
{
    stmt ** fStmts = (stmt **) arg1;
    while (IsComma(fExpr)) {
        stmt * fStmt = (stmt *) NewExprStmt(Cg->pLastSourceLoc, fExpr->bin.left);
        *fStmts = ConcatStmts(*fStmts, fStmt);
        fExpr = fExpr->bin.right;
    }

    return fExpr;
} // LinearizeCommasExpr

/*
 * FlattenCommas()
 *
 */

static stmt *FlattenCommasStmt(stmt *fStmt, void *arg1, int arg2)
{
    stmt *preCommaStmts = NULL;
    PreApplyToExpressionsLocal(FlattenCommasExpr, fStmt, NULL, 0);
    PreApplyToExpressionsLocal(LinearizeCommasExpr, fStmt, &preCommaStmts, 0);
    return ConcatStmts(preCommaStmts, fStmt);
} // FlattenCommas

///////////////////////////////////////////////////////////////////////////////////////////////
///////////////////////////////// Chop Matrices up into Vectors ///////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////

/*
 * DeconstructMatricesExpr()
 *
 */

expr *DeconstructMatricesExpr(expr *fExpr, void *arg1, int arg2)
{
    Symbol *lSymb;
    MData *mdata;
    Type *lType;
    int base, len, len2;
    int vname, index;

    mdata = (MData *) arg1;
    switch (fExpr->common.kind) {
    case BINARY_N:
        switch (fExpr->bin.op) {
        case ARRAY_INDEX_OP:
            lType = fExpr->bin.type;
            if (IsMatrix(fExpr->bin.left->common.type, &len, &len2)) {
                base = GetBase(lType);
                if (IsConstant(fExpr->bin.right)) {
                    if (IsVariable(fExpr->bin.left)) {
                        index = GetConstIndex(fExpr->bin.right);
                        vname = GenerateIndexName(fExpr->bin.left, index);
                        lSymb = LookUpLocalSymbol(mdata->scope, vname);
                        if (!lSymb)
                            lSymb = DefineVar(&lSymb->loc, mdata->scope, vname, lType);
                        fExpr = GenSymb(lSymb);
                    } else {
                        SemanticError(Cg->pLastSourceLoc, ERROR___MATRIX_NOT_SIMPLE);
                    }
                } else {
                    SemanticError(Cg->pLastSourceLoc, ERROR___ARRAY_INDEX_NOT_CONSTANT);
                }
            }
            break;
        default:
            break;
        }
        break;
    default:
        break;
    }
    return fExpr;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品在线一区二区| 精品国精品自拍自在线| 国产曰批免费观看久久久| 亚洲精品一二三四区| 精品国产一区二区精华| 欧洲国产伦久久久久久久| 国产剧情在线观看一区二区| 日日摸夜夜添夜夜添国产精品| 国产精品国产三级国产a| 日韩一区二区免费高清| 欧美三级在线视频| 色综合欧美在线| 成人污视频在线观看| 久久精品99国产精品日本| 天天色图综合网| 亚洲精品高清在线| 亚洲婷婷综合久久一本伊一区| 久久品道一品道久久精品| 欧美xxxxxxxx| 欧美成人福利视频| 日韩你懂的在线播放| 91精品国产欧美一区二区| 欧美性受极品xxxx喷水| 91美女片黄在线观看91美女| av动漫一区二区| 成人小视频在线| 岛国精品在线播放| 国产xxx精品视频大全| 国产精品一区二区在线观看网站| 日本伊人精品一区二区三区观看方式| 亚洲网友自拍偷拍| 亚洲成人免费在线| 日韩国产在线一| 日韩在线卡一卡二| 免费观看一级欧美片| 美美哒免费高清在线观看视频一区二区 | 日韩小视频在线观看专区| 666欧美在线视频| 欧美美女视频在线观看| 欧美丝袜丝交足nylons| 欧美丝袜丝nylons| 777奇米四色成人影色区| 欧美精品v国产精品v日韩精品 | 欧美一级二级三级蜜桃| 日韩欧美国产系列| 久久综合一区二区| 国产欧美精品在线观看| 中文字幕一区二区三区色视频| 中文字幕在线不卡一区| 亚洲精品视频自拍| 图片区小说区国产精品视频| 蜜桃久久精品一区二区| 韩国成人精品a∨在线观看| 国产99久久久久| www.欧美色图| 欧美日韩小视频| 日韩欧美亚洲国产精品字幕久久久| 精品福利在线导航| 国产精品视频在线看| 亚洲一区免费在线观看| 美日韩一级片在线观看| 丁香六月综合激情| 欧美性色黄大片| 精品国内片67194| 亚洲欧洲99久久| 日本不卡视频在线| 成人永久免费视频| 在线一区二区三区四区| 91精品国产综合久久福利软件| 久久久国际精品| 一级中文字幕一区二区| 日本va欧美va瓶| 国产精品白丝jk白祙喷水网站| 99re成人精品视频| 欧美一区二区黄色| 国产精品视频你懂的| 日韩在线a电影| 成年人国产精品| 日韩一区二区精品葵司在线| 国产精品国产三级国产aⅴ中文| 午夜av一区二区三区| 成人少妇影院yyyy| 678五月天丁香亚洲综合网| 国产精品毛片大码女人| 奇米精品一区二区三区四区| 波多野结衣在线一区| 欧美一区二区在线视频| 17c精品麻豆一区二区免费| 免费人成网站在线观看欧美高清| 成人禁用看黄a在线| 日韩片之四级片| 一个色在线综合| 东方欧美亚洲色图在线| 欧美一级在线观看| 亚洲永久免费av| 丰满放荡岳乱妇91ww| 欧美va亚洲va| 日韩国产精品久久久| 色偷偷久久一区二区三区| 久久精品一区二区三区av| 婷婷开心激情综合| 日本电影欧美片| 欧美激情一二三区| 激情图片小说一区| 在线不卡免费av| 一区二区三区精密机械公司| 国产成人8x视频一区二区| 精品免费日韩av| 免费成人在线网站| 欧美日韩国产精品自在自线| 亚洲精品你懂的| caoporn国产精品| 日本一区二区三区久久久久久久久不| 天天爽夜夜爽夜夜爽精品视频| 色播五月激情综合网| 国产精品久久久久一区| 国产精品一二一区| 精品国产露脸精彩对白| 久久国产精品99久久久久久老狼| 欧美猛男男办公室激情| 亚洲狠狠爱一区二区三区| 色久综合一二码| 亚洲综合免费观看高清完整版| 色偷偷成人一区二区三区91| 最好看的中文字幕久久| 97国产精品videossex| 亚洲视频每日更新| 成人激情动漫在线观看| 国产精品福利一区二区三区| 成人中文字幕电影| 中文字幕一区二区三区四区不卡| 成人免费不卡视频| 中文字幕一区二区三区在线播放 | 亚洲成年人影院| 欧美在线三级电影| 亚洲一区二区欧美激情| 欧美三级视频在线观看| 日韩精品亚洲专区| 日韩欧美一二区| 韩国av一区二区三区四区| 337p粉嫩大胆色噜噜噜噜亚洲| 精品写真视频在线观看| 久久久久久**毛片大全| 不卡的av电影在线观看| 亚洲精品视频在线看| 欧美日韩你懂得| 免费在线观看不卡| 精品国产制服丝袜高跟| 国产成人在线色| 1区2区3区国产精品| 欧美在线观看你懂的| 男女激情视频一区| 国产亚洲va综合人人澡精品| 成人免费看视频| 亚洲午夜一二三区视频| 欧美一级电影网站| 成人午夜碰碰视频| 一区二区三区四区视频精品免费 | 亚洲自拍偷拍麻豆| 91精品蜜臀在线一区尤物| 国内精品国产成人国产三级粉色| 国产女人水真多18毛片18精品视频| 波多野结衣一区二区三区| 一区二区三区高清在线| 91精品国产一区二区三区蜜臀 | 蜜桃一区二区三区在线观看| 久久综合色婷婷| 一本色道亚洲精品aⅴ| 日韩专区欧美专区| 国产亚洲精品福利| 欧美性做爰猛烈叫床潮| 国产呦萝稀缺另类资源| 亚洲素人一区二区| 欧美一区二区人人喊爽| jlzzjlzz欧美大全| 日韩一区欧美二区| 国产精品沙发午睡系列990531| 在线观看视频一区| 国产成人精品在线看| 亚洲在线一区二区三区| 国产网红主播福利一区二区| 色94色欧美sute亚洲13| 精品一区二区三区免费| 亚洲一区二区中文在线| 久久久久99精品一区| 欧美性极品少妇| 成人听书哪个软件好| 美女视频一区在线观看| 国产欧美一区二区三区在线看蜜臀| 欧美日韩一区三区| av成人动漫在线观看| 蜜桃视频在线观看一区| 亚洲精品免费播放| 国产日韩v精品一区二区| 欧美电影影音先锋| 色综合天天狠狠| 国产成人精品免费看| 亚洲一区二区在线播放相泽| 国产精品传媒在线| 久久久噜噜噜久噜久久综合|