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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? compile.c

?? nVidia開發(fā)的圖形語言 Cg
?? C
?? 第 1 頁 / 共 5 頁
字號:
expr *GenMatIndex(expr *mExpr, expr *xexpr, int base, int len, int len2)
{
    expr *lExpr;

    lExpr = (expr *) NewBinopNode(ARRAY_INDEX_OP, mExpr, xexpr);
    lExpr->bin.type = GetStandardType(base, len, 0);
    return lExpr;
} // GenMatIndex

/*
 * GenBoolConst() - Create a Boolean constant node.
 *
 */

expr *GenBoolConst(int fval)
{
    expr *lExpr;

    lExpr = (expr *) NewBConstNode(BCONST_OP, fval, TYPE_BASE_BOOLEAN);
    return lExpr;
} // GenBoolConst

/*
 * GenIntConst() - Create an integer constant node.
 *
 */

expr *GenIntConst(int fval)
{
    expr *lExpr;

    lExpr = (expr *) NewIConstNode(ICONST_OP, fval, TYPE_BASE_INT);
    return lExpr;
} // GenIntConst

/*
 * GenFConstV() - Create a vector floating point constant node.
 *
 */

expr *GenFConstV(float *fval, int len, int base)
{
    expr *lExpr;

    lExpr = (expr *) NewFConstNodeV(FCONST_V_OP, fval, len, base);
    return lExpr;
} // GenFConstV

/*
 * GenBoolNot() - Create a Boolean NOT.
 *
 */

expr *GenBoolNot(expr *fExpr)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP__(TYPE_BASE_BOOLEAN);
    lExpr = (expr *) NewUnopSubNode(BNOT_OP, lsubop, fExpr);
    lExpr->un.type = BooleanType;
    return lExpr;
} // GenBoolNot

/*
 * GenBoolAssign() - Create a Boolean assignment.
 *
 */

expr *GenBoolAssign(expr *fVar, expr *fExpr)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP__(TYPE_BASE_BOOLEAN);
    lExpr = (expr *) NewBinopSubNode(ASSIGN_OP, lsubop, fVar, fExpr);
    lExpr->bin.type = BooleanType;
    return lExpr;
} // GenBoolAssign

/*
 * GenSAssign() - Create a scalar assignment.
 *
 */

expr *GenSAssign(expr *fVar, expr *fExpr, int base)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_S(base);
    lExpr = (expr *) NewBinopSubNode(ASSIGN_OP, lsubop, fVar, fExpr);
    lExpr->bin.type = GetStandardType(base, 0, 0);
    return lExpr;
} // GenSAssign

/*
 * GenVAssign() - Create a vector assignment.
 *
 */

expr *GenVAssign(expr *fVar, expr *fExpr, int base, int len)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_V(len, base);
    lExpr = (expr *) NewBinopSubNode(ASSIGN_V_OP, lsubop, fVar, fExpr);
    lExpr->bin.type = GetStandardType(base, len, 0);
    return lExpr;
} // GenCondSVAssign

/*
 * GenMAssign() - Create a matrix assignment.
 *
 */

expr *GenMAssign(expr *fVar, expr *fExpr, int base, int len, int len2)
{
    expr *lExpr;

    lExpr = (expr *) NewBinopNode(ASSIGN_GEN_OP, fVar, fExpr);
    lExpr->bin.type = GetStandardType(base, len, len2);
    return lExpr;
} // GenMAssign

/*
 * GenCondSAssign() - Create a scalar conditional assignment.
 *
 */

expr *GenCondSAssign(expr *fVar, expr *fCond, expr *fExpr, int base)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_S(base);
    lExpr = (expr *) NewTriopSubNode(ASSIGN_COND_OP, lsubop, fVar, fCond, fExpr);
    lExpr->tri.type = GetStandardType(base, 0, 0);
    return lExpr;
} // GenCondSAssign

/*
 * GenCondSVAssign() - Create a vector conditional assignment with a scalar Boolean argument.
 *
 */

expr *GenCondSVAssign(expr *fVar, expr *fCond, expr *fExpr, int base, int len)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_SV(len, base);
    lExpr = (expr *) NewTriopSubNode(ASSIGN_COND_SV_OP, lsubop, fVar, fCond, fExpr);
    lExpr->tri.type = GetStandardType(base, len, 0);
    return lExpr;
} // GenCondSVAssign

/*
 * GenCondVAssign() - Create a vector conditional assignment with a vector Boolean argument.
 *
 */

expr *GenCondVAssign(expr *fVar, expr *fCond, expr *fExpr, int base, int len)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_V(len, base);
    lExpr = (expr *) NewTriopSubNode(ASSIGN_COND_V_OP, lsubop, fVar, fCond, fExpr);
    lExpr->tri.type = GetStandardType(base, len, 0);
    return lExpr;
} // GenCondVAssign

/*
 * GenCondGenAssign() - Create a geeral conditional assignment.
 *
 */

expr *GenCondGenAssign(expr *fVar, expr *fCond, expr *fExpr)
{
    expr *lExpr;
    int lsubop;

    lsubop = 0;
    lExpr = (expr *) NewTriopSubNode(ASSIGN_COND_GEN_OP, lsubop, fVar, fCond, fExpr);
    lExpr->tri.type = fVar->common.type;
    return lExpr;
} // GenCondGenAssign

/*
 * GenBoolAnd() - Create a Boolean &&.
 *
 */

expr *GenBoolAnd(expr *aExpr, expr *bExpr)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP__(TYPE_BASE_BOOLEAN);
    lExpr = (expr *) NewBinopSubNode(BAND_OP, lsubop, aExpr, bExpr);
    lExpr->bin.type = BooleanType;
    return lExpr;
} // GenBoolAnd

/*
 * GenBoolAndVec() - Create a Boolean Vector &&.
 *
 */

expr *GenBoolAndVec(expr *aExpr, expr *bExpr, int len)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_V(len, TYPE_BASE_BOOLEAN);
    lExpr = (expr *) NewBinopSubNode(BAND_V_OP, lsubop, aExpr, bExpr);
    lExpr->bin.type = GetStandardType(TYPE_BASE_BOOLEAN, len, 0);
    return lExpr;
} // GenBoolAndVec

/*
 * GenBoolSmear() - Smear a Boolean Vector @xxxx.
 *
 */

expr *GenBoolSmear(expr *fExpr, int len)
{
    expr *lExpr;
    int lsubop, mask;

    mask = (0 << 6) | (0 << 4) | (0 << 2) | 0;
    lsubop = SUBOP_Z(mask, len, 0, TYPE_BASE_BOOLEAN);
    lExpr = (expr *) NewUnopSubNode(SWIZZLE_Z_OP, lsubop, fExpr);
    lExpr->bin.type = GetStandardType(TYPE_BASE_BOOLEAN, len, 0);
    return lExpr;
} // GenBoolSmear

/*
 * GenExprList() - Add a node to an expression list.
 *
 */

expr *GenExprList(expr *fExpr, expr *nExpr, Type *ftype)
{
    expr *lExpr, *tExpr;

    lExpr = (expr *) NewBinopNode(EXPR_LIST_OP, nExpr, NULL);
    lExpr->common.type = ftype;
    if (fExpr) {
        tExpr = fExpr;
        while (tExpr->bin.right)
            tExpr = tExpr->bin.right;
        tExpr->bin.right = lExpr;
    } else {
        fExpr = lExpr;
    }
    return fExpr;
} // GenExprList

/*
 * GenVecMult() - Create a Vector Multiply
 *
 */

expr *GenVecMult(expr *aExpr, expr *bExpr, int base, int len)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_V(len, base);
    lExpr = (expr *) NewBinopSubNode(MUL_V_OP, lsubop, aExpr, bExpr);
    lExpr->bin.type = GetStandardType(base, len, 0);
    return lExpr;
} // GenVecMult

/*
 * GenScaleVecMult() - Create a smeared Scalar-Vector Multiply
 *
 */

expr *GenScaleVecMult(expr *aExpr, expr *bExpr, int base, int len)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_V(len, base);
    lExpr = (expr *) NewBinopSubNode(MUL_VS_OP, lsubop, aExpr, bExpr);
    lExpr->bin.type = GetStandardType(base, len, 0);
    return lExpr;
} // GenScaleVecMult

/*
 * GenVecAdd() - Create a Vector Addition
 *
 */

expr *GenVecAdd(expr *aExpr, expr *bExpr, int base, int len)
{
    expr *lExpr;
    int lsubop;

    lsubop = SUBOP_V(len, base);
    lExpr = (expr *) NewBinopSubNode(ADD_V_OP, lsubop, aExpr, bExpr);
    lExpr->bin.type = GetStandardType(base, len, 0);
    return lExpr;
} // GenVecAdd

/*
 * GenConvertVectorSize() - Convert a vector to another length, or to a scalar if newlen is 1.
 *        Return original expression if no conversion needed.
 */

expr *GenConvertVectorLength(expr *fExpr, int base, int len, int newlen)
{
    int mask, ii;
    expr *lExpr;

    if (newlen != len) {
        for (ii = 0; ii < newlen; ii++) {
            if (ii < len) {
                mask |= ii << (ii*2);
            } else {
                mask |= len - 1; // Use last component if source shorter than dest
            }
        }
        if (newlen == 1)
            newlen = 0; // I.e. scalar, not array[1]
        lExpr = (expr *) NewUnopSubNode(SWIZZLE_Z_OP, SUBOP_Z(mask, newlen, len, base), fExpr);
        lExpr->un.type = GetStandardType(base, newlen, 0);
    } else {
        lExpr = fExpr;
    }
    return lExpr;
} // GenConvertVectorLength

///////////////////////////////////////////////////////////////////////////////////////////////
///////////////////////////////////// Duplicate Functions /////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////

/*
 * DuplicateNode() - Duplicate a node.
 *
 */

expr *DuplicateNode(expr *fExpr, void *arg1, int arg2)
{
    expr *lExpr;

    if (fExpr) {
        switch (fExpr->common.kind) {
        case SYMB_N:
            lExpr = (expr *) DupSymbNode(&fExpr->sym);
            break;
        case CONST_N:
            lExpr = (expr *) DupConstNode(&fExpr->co);
            break;
        case UNARY_N:
            lExpr = (expr *) DupUnaryNode(&fExpr->un);
            break;
        case BINARY_N:
            lExpr = (expr *) DupBinaryNode(&fExpr->bin);
            break;
        case TRINARY_N:
            lExpr = (expr *) DupTrinaryNode(&fExpr->tri);
            break;
        default:
            assert(!"bad kind to DuplicateNode()");
            lExpr = fExpr;
            break;
        }
    } else {
        lExpr = NULL;
    }
    return lExpr;
} // DuplicateNode

/*
 * DupExpr() - Duplicate an expression tree.
 *
 */

expr *DupExpr(expr *fExpr)
{
    return PreApplyToNodes(DuplicateNode, fExpr, NULL, 0);
} // DupExpr

/*
 * DuplicateStatement() - Duplicate a statement.
 *
 */

stmt *DuplicateStatement(stmt *fStmt, void *arg1, int arg2)
{
    stmt *lStmt;

    if (fStmt) {
        switch (fStmt->commonst.kind) {
        case EXPR_STMT:
            lStmt = (stmt *) NewExprStmt(&fStmt->commonst.loc, fStmt->exprst.exp);
            break;
        case IF_STMT:
            lStmt = (stmt *) NewIfStmt(&fStmt->commonst.loc, fStmt->ifst.cond,
                                fStmt->ifst.thenstmt, fStmt->ifst.elsestmt);
            break;
        case WHILE_STMT:
        case DO_STMT:
            lStmt = (stmt *) NewWhileStmt(&fStmt->commonst.loc, fStmt->whilest.kind,
                                fStmt->whilest.cond, fStmt->whilest.body);
            break;
        case FOR_STMT:
            lStmt = (stmt *) NewForStmt(&fStmt->commonst.loc, fStmt->forst.init,
                                fStmt->forst.cond, fStmt->forst.step, fStmt->forst.body);
            break;
        case BLOCK_STMT:
            lStmt = (stmt *) NewBlockStmt(&fStmt->commonst.loc, fStmt->blockst.body);
            break;
        case RETURN_STMT:
            lStmt = (stmt *) NewReturnStmt(&fStmt->commonst.loc, NULL, fStmt->exprst.exp);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91女神在线视频| 国产乱人伦偷精品视频免下载 | 精品久久久久av影院| 欧美日韩国产区一| 欧美一区二区三级| 精品少妇一区二区三区视频免付费| 91精彩视频在线观看| 欧美色图免费看| 91精品国产综合久久婷婷香蕉| 日韩一区二区三区电影| 久久久激情视频| 亚洲精品免费电影| 日韩精品国产精品| 国产大陆亚洲精品国产| 91高清视频在线| 日韩欧美aaaaaa| 亚洲美女视频在线观看| 日韩成人精品视频| 风流少妇一区二区| 欧美高清激情brazzers| 中日韩免费视频中文字幕| 亚洲一区二区精品久久av| 免费成人av在线| youjizz国产精品| 久久综合久久综合久久| 亚洲一区在线观看网站| 韩国欧美一区二区| 国产日韩欧美高清在线| 三级影片在线观看欧美日韩一区二区| 久久爱另类一区二区小说| 日本福利一区二区| 中文字幕av免费专区久久| 精品亚洲porn| 欧美大片在线观看| 午夜精品久久久久久久久久久| 91丨九色丨尤物| 中文字幕制服丝袜一区二区三区 | 欧美视频一区在线| 国产欧美一区视频| 韩国视频一区二区| wwwwww.欧美系列| 国产精品一卡二卡在线观看| 精品成人私密视频| 极品美女销魂一区二区三区| 日韩亚洲欧美高清| 久久99精品国产91久久来源| 欧美一区二区观看视频| 青青草国产成人99久久| 精品日韩欧美一区二区| 黄页视频在线91| 日本一区二区三区视频视频| 高潮精品一区videoshd| 一区二区三区加勒比av| 欧美剧情电影在线观看完整版免费励志电影 | 国产精品无码永久免费888| 国产精品夜夜嗨| 亚洲综合色噜噜狠狠| 日韩一二三区不卡| 国产盗摄一区二区三区| 亚洲女同ⅹxx女同tv| 日韩免费观看高清完整版| kk眼镜猥琐国模调教系列一区二区| 国产精品成人在线观看| 欧美一二三区在线观看| 成人av电影免费观看| 久久精品72免费观看| 最新国产成人在线观看| 日韩视频一区在线观看| 色综合亚洲欧洲| 精品一区二区三区在线播放视频 | 成人美女在线视频| 蜜乳av一区二区三区| 一区二区三区在线看| 日本一区二区三区高清不卡| 欧美日本一区二区三区| 99精品国产视频| 成人激情免费网站| 国产综合色视频| 日本成人在线网站| 亚洲一二三四久久| 一区二区三区欧美在线观看| 欧美激情艳妇裸体舞| 久久蜜桃一区二区| 久久久久久久免费视频了| 9191成人精品久久| 欧美日韩不卡一区| 欧美日韩一区二区三区在线| 欧美午夜一区二区三区免费大片| 在线观看视频欧美| 欧美日韩午夜在线| 欧美一区在线视频| 日韩一区二区在线观看视频| 日韩精品影音先锋| 久久网这里都是精品| 国产欧美精品一区二区三区四区| 中文字幕欧美激情一区| 欧美午夜电影网| 久久综合网色—综合色88| 欧美精品一区二区久久婷婷| 亚洲精品一区二区三区蜜桃下载 | 欧美丝袜丝交足nylons| 欧美顶级少妇做爰| 欧美韩国日本一区| 亚州成人在线电影| 国产成人亚洲精品青草天美| 成人免费av资源| 欧美日韩精品一区二区三区| 91精品国产91久久久久久最新毛片| 精品国产91久久久久久久妲己| 国产亚洲一区二区三区四区| 亚洲一区在线观看视频| 国产精品一区在线| 欧美日本一区二区三区四区| 国产女同性恋一区二区| 亚洲成精国产精品女| 成人app在线观看| 亚洲精品一区二区三区香蕉| 亚洲成av人片在线| 99热精品一区二区| 国产精品丝袜一区| 国产美女精品一区二区三区| 欧美另类videos死尸| 一区二区三区毛片| 91成人在线观看喷潮| 国产精品国模大尺度视频| 久久成人精品无人区| 欧美视频一区在线| 中文字幕在线不卡视频| 亚洲乱码精品一二三四区日韩在线| 精品亚洲成a人| 欧美刺激脚交jootjob| 午夜精品福利视频网站| 成人网在线播放| 亚洲欧美在线视频观看| 国产+成+人+亚洲欧洲自线| 欧美大尺度电影在线| 日韩综合小视频| 欧美一级黄色录像| 五月婷婷激情综合| 日韩视频一区二区三区| 精品一区二区在线视频| 日韩一卡二卡三卡四卡| 麻豆成人91精品二区三区| 日韩精品中文字幕一区二区三区 | 国产精品免费aⅴ片在线观看| 国产一区二区0| 久久午夜国产精品| 国产一区二区视频在线| 国产调教视频一区| 91视频精品在这里| 午夜天堂影视香蕉久久| 日韩免费看的电影| 国产成人av资源| 五月天激情综合| 久久精品一区蜜桃臀影院| 99精品国产视频| 亚洲精品免费视频| 久久婷婷综合激情| 91视频www| 老司机免费视频一区二区| 精品久久久久久久一区二区蜜臀| av亚洲精华国产精华精华| 丝袜美腿亚洲一区| 国产亚洲精品7777| 欧美成人福利视频| 色www精品视频在线观看| 久久av中文字幕片| 亚洲综合激情网| 亚洲黄色免费电影| xf在线a精品一区二区视频网站| 色综合视频在线观看| 午夜精品福利一区二区三区av| 国产精品免费视频网站| 91精品在线免费| 色成年激情久久综合| 成人免费高清在线| 韩国理伦片一区二区三区在线播放| 亚洲第一精品在线| 亚洲一区二区视频在线观看| 久久久国产精品午夜一区ai换脸| 这里只有精品免费| 欧美精品三级日韩久久| 日韩欧美电影在线| 日韩视频一区二区三区在线播放| 91国偷自产一区二区使用方法| 国产成人综合自拍| 国产一区二区0| 国产精品亚洲а∨天堂免在线| 日韩国产一二三区| 国产一区二区三区在线观看免费| 欧美a级一区二区| 老司机精品视频导航| 国产在线播放一区三区四| 久久99精品国产麻豆不卡| 国产精品一区不卡| 国产主播一区二区三区| 国产综合色在线| 成人成人成人在线视频| 色综合色狠狠天天综合色| 91精品中文字幕一区二区三区|