當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript traverse.default函數代碼示例

本文整理匯總了TypeScript中traverse.default函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript default函數的具體用法?TypeScript default怎麽用?TypeScript default使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了default函數的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: coerceValues

function coerceValues(configData: any) {
    return traverse(configData).forEach(function(value: any) {
        if (this.isLeaf && !_.isUndefined(value)) {
            // Allow env vars to define boolean values
            if (value === 'true') {
                this.update(true);
            }
            else if (value === 'false') {
                this.update(false);
            }
            else if (value === 'undefined') {
                this.update(void 0);
            }
        }
    });
}
開發者ID:NickHeiner,項目名稱:lambdascript,代碼行數:16,代碼來源:index.ts

示例2: if

napkin.addGenerator("text", (obj) => {

    var s = "";

    traverse(obj).forEach(function to_s(node) {

        if (Array.isArray(node)) {
            // this.post(function (child) {
            //    if (!child.isLast) s += ',';
            //});
            //this.after(function () { s += ']' });
        }
        else if (typeof node == 'object') {

            this.before(function () {
                if (node.node) {
                    s += Array(Math.floor(this.level/2)).join("\t") + node.node + "\n";
                }
            });

            //this.pre(function (x, key) {
            //    to_s(key);
            //    s += ':';
            //});

            //this.post(function (child) {
            //    if (!child.isLast) s += ',';
            //});

            //this.after(function () { s += '}' });
        }
        else if (typeof node == 'string') {
            //s += '"' + node.toString().replace(/"/g, '\\"') + '"';
        }
        else {
            s += node.toString();
        }


    });

    return s;

});
開發者ID:joeriks,項目名稱:napkin,代碼行數:44,代碼來源:napkin-generator-text.ts

示例3: traverse

napkin.addGenerator("cs", (obj) => {

    var s = "";

    traverse(obj).forEach(function to_s(node) {

        if (typeof node == 'object') {

            this.before(function () {
                if (node.node) {

                    if (this.level == 1) {
                        s += "namespace " + node.node + " {\n";
                    }
                    if (this.level == 3) {
                        s += "\tpublic class " + node.node + " {\n";
                    }
                    if (this.level == 5) {
                        s += "\t\tpublic string " + node.node + " {get;set;}\n";
                    }

                    
                }
            });

            this.after(function () {
                if (this.level == 1) {
                    s += "}\n";
                }
                if (this.level == 3) {
                    s += "\t}\n";
                }
            });
        }

    });

    return s;

});
開發者ID:joeriks,項目名稱:napkin,代碼行數:40,代碼來源:napkin-generator-cs.ts

示例4: getHighlightedCode

function getHighlightedCode(lscAst: ILambdaScriptAstNode, lambdaScriptCode: string) {
    const codeByLines = _str.lines(lambdaScriptCode),
        colorActions = traverse(lscAst)
            .reduce(function(colorActions: ILineColorAction[], astNode: ILambdaScriptAstNode) {
                const color = colorMap[astNode.type];

                if (color) {
                    const colorFn = chalk[color].bind(chalk),
                        locKey = alternateLocMap[astNode.type] || 'loc',

                        // I'm just using _.result to avoid TS7017
                        loc: ILoc = _.result(astNode, locKey);

                    /**
                     * Originally, I just colored as soon as I found a node. However, this does not work,
                     * because other coloring may have occurred on the line already, which will offset our
                     * column indices. And it is not sufficient just to drop all color from the line and
                     * see what the length difference is, because some of that color could be *after* our
                     * column indices and thus irrelevant. To solve this, we will gather all the colorings
                     * we want to do, and then apply them in sorted order. This makes the offset caclulation trivial.
                     */
                    return colorActions.concat({
                        // I don't know why but jison does not 0-index the line number.
                        lineIndex: loc.first_line - 1,
                        colStart: loc.first_column,
                        colEnd: loc.last_column,
                        colorFn: colorFn
                    });
                }

                return colorActions;
            }, []),

        coloredCode = _(colorActions)
            .sortByAll(['lineIndex', 'colStart'])
            .reduce(function(lines: string[], colorAction: ILineColorAction) {

                const linesClone = _.clone(lines),
                    lineToColor = linesClone[colorAction.lineIndex],

                    existingColorOffset = lineToColor.length - chalk.stripColor(lineToColor).length,

                    colStartWithOffset = colorAction.colStart + existingColorOffset,
                    colEndWithOffset = colorAction.colEnd + existingColorOffset;

                // One potential way to fail fast here would be to detect when we are coloring
                // over an existing highlight. I have yet to encounter a case where that was expected behavior.

                linesClone[colorAction.lineIndex] =
                    lineToColor.slice(0, colStartWithOffset) +
                    colorAction.colorFn(lineToColor.slice(colStartWithOffset, colEndWithOffset)) +
                    lineToColor.slice(colEndWithOffset);

                logger.debug({
                    original: lines[colorAction.lineIndex],
                    colored: linesClone[colorAction.lineIndex]
                }, 'Coloring line');

                return linesClone;
            }, codeByLines);

    return coloredCode.join(os.EOL);
}
開發者ID:NickHeiner,項目名稱:lambdascript,代碼行數:63,代碼來源:get-highlighted-code.ts

示例5: runCommands

function runCommands(objectToParse: idocument): any {

    function cmd_include(filename, type) {

        var included = parseFile(filename, false);

        if (included) {
            var arr = [];
            for (var i = 0; i < included.length; i++) {

                var item = included[i];

                item["included"] = type;

                arr.push(item);

            }

            objectToParse.document = arr.concat(objectToParse.document);
        }

    }

    function cmd_map(filename) {

        var req = require("./" + filename);
        objectToParse = req(objectToParse);

    }

    function cmd_out(filename, type?) {

        if (!type) {
            type = path.extname(filename);
            if (type.indexOf(".") == 0)
                type = type.substring(1);
            else
                type = "text";
        }

        if (!objectToParse.processed) {

            objectToParse.processed = objectToParse.document.slice(0);
            //processAll(objectToParse.processed);

            var newChildArray = [];
            for (var ii in objectToParse.processed) {
                var node = objectToParse.processed[ii];
                if (!(node["included"] && node["included"] == "reference")) {
                    newChildArray.push(objectToParse.processed[ii]);
                } else {
                    console.log("excluded " + node.name);
                }
            }

            objectToParse.processed = newChildArray;

        }

        var formatted = generate(objectToParse.processed, type);

        fs.writeFileSync(filename, formatted);

    }

    traverse(objectToParse.document).forEach(function on_item(item) {
        if (item.name) {

            if (item.name.indexOf("/") == 0) {

                item.isCommand = true;

                if (item.name == "/out") {
                    cmd_out(item.attributes[0]);
                }
                if (item.name == "/reference") {
                    cmd_include(item.attributes[0], "reference");
                }
                if (item.name == "/include") {
                    cmd_include(item.attributes[0], "include");
                }
            }

        }
    });

    //if (objectToParse.commands) {

    //    var commands = objectToParse.commands.splice(0);

    //    for (var c in commands) {

    //        var cmd = commands[c];

    //        if (cmd.type == "include" || cmd.type == "reference") cmd_include(cmd.attributes[0].attr, cmd.type);

    //        if (cmd.type == "map") cmd_map(cmd.attributes[0].attr);

    //        if (cmd.type == "processall") processAll(objectToParse.model);

//.........這裏部分代碼省略.........
開發者ID:joeriks,項目名稱:napkin,代碼行數:101,代碼來源:napkin.ts

示例6: assignStateDeep

function assignStateDeep(self, callback, stateList, parseFunc, newValue) {
  traverse(self.state).set(stateList, parseFunc(newValue));
  //setState
  self.setState(self.state, callback);
}
開發者ID:my-koop,項目名稱:module.core,代碼行數:5,代碼來源:assignStateDeep.ts


注:本文中的traverse.default函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。