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


TypeScript common.Str類代碼示例

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


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

示例1: getProcessedHelp

    public getProcessedHelp() {
        const tokens = {
            "%name%": this.name,
        };

        return Str.replace(this.help, tokens);
    }
開發者ID:sirian,項目名稱:node-component-console,代碼行數:7,代碼來源:CommandDefinition.ts

示例2: getSynopsis

    public getSynopsis() {
        const messages = [super.getSynopsis()];

        const choices = this.getChoices();

        const keys: any[] = KV.keys(choices); // todo: remove any[], typescript issue at keys.map
        const widths = keys.map((key: any) => StrUtil.width(key));

        const width = Math.max(...widths);

        for (const [key, value] of KV.entries(choices)) {
            const k = Var.stringify(key);
            messages.push(`  [<comment>${Str.padLeft(k, width)}</comment>] ${value}`);
        }
        return messages.join("\n");
    }
開發者ID:sirian,項目名稱:node-component-console,代碼行數:16,代碼來源:ChoiceQuestion.ts

示例3: getNames

    public getNames(ns: string = "") {
        const commands = new XSet<string>();

        const names = [...this.commands.keys()];
        if (this.commandLoader) {
            names.push(...this.commandLoader.getNames());
        }

        for (const name of names) {
            if (!ns || ns === this.extractNamespace(name, Str.substringCount(ns, ":") + 1)) {
                commands.add(name);
            }
        }

        return commands.toArray();
    }
開發者ID:sirian,項目名稱:node-component-console,代碼行數:16,代碼來源:Application.ts

示例4: renderError

    public renderError(e: Error) {
        const stack = ErrorStackParser.parse(e);

        const output = this.errorOutput;

        let len = 0;
        let title = "";

        const message = Var.stringify(e.message).trim();

        if ("" === message || output.isVerbose()) {
            title = `  [${e.name || e.constructor.name}]  `;
            len = StrUtil.width(title);
        }

        const width = output.getWidth();
        const lines: Array<[string, number]> = [];

        if (message) {
            for (const line of message.split(/\r?\n/)) {
                for (const chunk of StrUtil.splitByWidth(line, width - 4)) {
                    const lineLength = StrUtil.width(chunk) + 4;
                    lines.push([chunk, lineLength]);
                    if (lineLength > len) {
                        len = lineLength;
                    }
                }
            }
        }

        const messages = [];

        const emptyLine = `<error>${StrUtil.spaces(len)}</error>`;

        messages.push(emptyLine);

        if ("" === message || output.isVerbose()) {
            messages.push(`<error>${Str.padRight(title, len)}</error>`);
        }

        for (const [line, lineLength] of lines) {
            messages.push(`<error>  ${Formatter.escape(line)}  ${StrUtil.spaces(len - lineLength)}</error>`);
        }

        messages.push(emptyLine);
        messages.push("");

        if (output.isVerbose() && stack.length) {
            messages.push("<comment>Error trace:</comment>");

            for (const frame of stack) {
                const fn = frame.functionName || "{anonymous}";
                const args = (frame.args || []).join(", ");
                const file = frame.fileName || "";
                const line = frame.lineNumber;
                const col = frame.columnNumber;

                messages.push(
                    Formatter.format(`  %s(%s) at <info>%s</info> <comment>%d:%d</comment>`, fn, args, file, line, col),
                );
            }
            messages.push("");
            messages.push("");
        }

        output.writeln(messages, {verbosity: OutputVerbosity.QUIET});
    }
開發者ID:sirian,項目名稱:node-component-console,代碼行數:67,代碼來源:IO.ts

示例5:

 .map((a) => Str.padRight(a.join(""), width, " "));
開發者ID:sirian,項目名稱:node-component-console,代碼行數:1,代碼來源:StrUtil.ts

示例6: find

    public async find(name: string) {
        const commands = this.commands;
        const commandNames = [...commands.keys()];
        if (this.commandLoader) {
            commandNames.push(...this.commandLoader.getNames());
        }

        const expr = name.replace(/([^:]+|)/, (text) => Rgx.escape(text) + "[^:]*");

        const re = new RegExp("^" + expr);
        const rei = new RegExp("^" + expr, "i");
        let found = commandNames.filter((c) => re.test(c));

        if (!found.length) {
            found.push(...commandNames.filter((c) => rei.test(c)));
        }

        // if no found matched or we just matched namespaces
        if (!found.length || !found.filter((c) => rei.test(c)).length) {
            if (name.includes(":")) {
                // check if a namespace exists and contains found
                const pos = name.indexOf(":");
                this.findNamespace(name.substr(0, pos));
            }

            let message = `Command "${name}" is not defined.`;

            const alternatives = this.findAlternatives(name, commandNames);
            if (alternatives.length) {
                if (1 === alternatives.length) {
                    message += "\n\nDid you mean this?\n    ";
                } else {
                    message += "\n\nDid you mean one of these?\n    ";
                }
                message += alternatives.join("\n    ");
            }

            throw new CommandNotFoundError(message, alternatives);
        }

        const aliases = new Map();

        // filter out aliases for found which are already on the list
        if (found.length > 1) {
            const filteredCommands = new Set<string>();

            for (const nameOrAlias of found) {
                let commandName = nameOrAlias;

                if (commands.has(nameOrAlias)) {
                    const command = commands.get(nameOrAlias)!;
                    commandName = command.getDefinition().getName();
                }

                aliases.set(nameOrAlias, commandName);

                if (commandName === nameOrAlias || !found.includes(commandName)) {
                    filteredCommands.add(nameOrAlias);
                }
            }

            found = [...filteredCommands];
        }

        const exact = found.includes(name) || aliases.has(name);

        if (found.length > 1 && !exact) {
            const widths = found.map((abbr) => StrUtil.width(abbr));
            const maxLen = Math.max(...widths);

            const abbrevs = [];
            for (const cmdName of found) {
                const command = await this.getCommand(cmdName);

                const description = command.getDefinition().getDescription();
                const abbr = sprintf("%s %s", Str.padRight(cmdName, maxLen), description);
                abbrevs.push(abbr);
            }

            const suggestions = this.getAbbreviationSuggestions(abbrevs);

            throw new CommandNotFoundError(
                `Command "${name}" is ambiguous.\nDid you mean one of these?\n${suggestions}`,
                found,
            );
        }

        return this.getCommand(exact ? name : found[0]);
    }
開發者ID:sirian,項目名稱:node-component-console,代碼行數:89,代碼來源:Application.ts

示例7: render

    public render(messages: string | string[]) {
        messages = Arr.cast(messages);
        const options = this.options;

        const padding = options.padding || [];
        const padTop = padding.length > 0 ? padding[0] : 0;
        const padRight = padding.length > 1 ? padding[1] : padTop;
        const padBottom = padding.length > 2 ? padding[2] : padTop;
        const padLeft = padding.length > 3 ? padding[3] : padRight;

        const lines: string[] = [];
        const output = this.output;
        const formatter = output.getFormatter();

        const type = Var.stringify(options.type);
        const typeWidth = type ? StrUtil.width(type) + 1 : 0;

        const maxMessageWidth = Math.max(
            options.minWidth,
            ...messages.map((msg) => formatter.widthWithoutDecoration(msg)),
        );

        const maxWidth = Math.min(
            output.getWidth(),
            options.maxWidth,
            maxMessageWidth + typeWidth + padRight + padLeft,
        );

        const chunkWidth = maxWidth - typeWidth - padLeft - padRight;

        for (const message of messages) {
            const chunks = StrUtil.splitByWidth(message, chunkWidth);

            for (const chunk of chunks) {
                const prefix = 0 === lines.length ? type : "";

                const parts = [
                    StrUtil.spaces(padLeft),
                    Str.padRight(prefix, typeWidth),
                    Str.padRight(chunk, chunkWidth),
                    StrUtil.spaces(padRight),
                ];

                lines.push(parts.join(""));
            }
        }

        const emptyLine = StrUtil.spaces(maxWidth);

        if (output.isDecorated()) {
            for (let i = 0; i < padTop; i++) {
                lines.unshift(emptyLine);
            }
            for (let i = 0; i < padBottom; i++) {
                lines.push(emptyLine);
            }
        }

        for (const line of lines) {
            const text = Formatter.formatText(line, options.style);

            output.writeln(text);
        }
    }
開發者ID:sirian,項目名稱:node-component-console,代碼行數:64,代碼來源:Block.ts


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