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


TypeScript TextEditor.getText方法代碼示例

本文整理匯總了TypeScript中atom.TextEditor.getText方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript TextEditor.getText方法的具體用法?TypeScript TextEditor.getText怎麽用?TypeScript TextEditor.getText使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在atom.TextEditor的用法示例。


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

示例1: editorFormat

 function editorFormat(input: string) {
   editor.setText(input)
   if (opts.selectBeforeTest) {
     editor.setSelectedBufferRange(editor.getBuffer().getRange())
   }
   atom.commands.dispatch(
     atom.views.getView(editor),
     'markdown-table-formatter:format',
   )
   return editor.getText()
 }
開發者ID:fcrespo82,項目名稱:atom-markdown-table-formatter,代碼行數:11,代碼來源:editor.spec.ts

示例2: prettifyFile

export async function prettifyFile(editor: TextEditor) {
  const [firstCursor, ...cursors] = editor
    .getCursors()
    .map((cursor) => cursor.getBufferPosition())
  const format = editor.getGrammar().scopeName
  const prettify = format === 'source.cabal' ? cabalFormat : filterFormat
  const workDir = (await getRootDir(editor.getBuffer())).getPath()
  try {
    const { stdout, stderr } = await prettify(
      editor.getText(),
      workDir,
      editor.getRootScopeDescriptor(),
    )
    editor.setText(stdout)
    const lastCursor = editor.getLastCursor()
    if (lastCursor) {
      lastCursor.setBufferPosition(firstCursor, { autoscroll: false })
    }
    cursors.forEach((cursor) => {
      editor.addCursorAtBufferPosition(cursor, { autoscroll: false })
    })
    if (stderr.length > 0) {
      atom.notifications.addWarning(
        'Prettifier reported the following problems:',
        {
          detail: stderr,
          dismissable: true,
        },
      )
    }
  } catch (e) {
    const err: Error = e.error || e
    let stderr: string = e.stderr ? e.stderr.trim() : ''
    if (err.message.includes(stderr)) {
      stderr = ''
    }
    atom.notifications.addError('Failed to prettify', {
      detail: `${stderr ? `${stderr}\n\n` : ''}${err.message}`,
      stack: err.stack,
      dismissable: true,
    })
  }
}
開發者ID:atom-haskell,項目名稱:ide-haskell,代碼行數:43,代碼來源:index.ts

示例3: async

  lint: async (textEditor: TextEditor): Promise<LintResult> => {
    const filePath = textEditor.getPath();

    if (!filePath) {
      // The current TextEditor has no path associated with it.
      return null;
    }

    const input = textEditor.getText();

    const command = atom.config.get("linter-swiftlint.swiftlintExecutablePath");
    if (!fs.existsSync(command)) {
      return null;
    }

    const parameters = ["lint", "--use-stdin"];
    let config = path.normalize(
      atom.config.get("linter-swiftlint.configurationPath")
    );

    if (filePath && !path.isAbsolute(config)) {
      config =
        atom.project
          .getDirectories()
          .filter(directory => directory.contains(filePath))
          .map(directory => directory.getFile(config).getPath())
          .find(() => true) || config; // take first item if exists
    }

    if (config && fs.existsSync(config)) {
      parameters.push("--config", config);
    }

    const additionalOptions = atom.config.get(
      "linter-swiftlint.additionalOptions"
    );
    if (additionalOptions) {
      parameters.push(additionalOptions);
    }

    const options = {
      ignoreExitCode: true,
      stdin: input,
      throwOnStderr: false
    };

    const output = await helpers.exec(command, parameters, options);

    const messages: Message[] = [];
    let match = regex.exec(output);
    while (match !== null) {
      const line = Math.max(Number.parseInt(match[1], 10) - 1, 0);
      const col = Math.max(Number.parseInt(match[2], 10) - 1, 0);
      let position: Range;
      try {
        position = helpers.generateRange(textEditor, line, col);
      } catch(e) {
        // If the position wasn't valid, just return the start of the file
        // NOTE: Ideally this would handle the error and give the user an easy
        // way to report it for eventual fixing.
        position = new Range([0, 0], [0, Number.POSITIVE_INFINITY]);
      }

      const type = match[3].toLowerCase();
      const severity =
        type === 'error' || type === 'warning' || type === 'info' ?
        type : 'error';

      messages.push({
        severity,
        excerpt: match[4],
        location: {
          file: filePath,
          position,
        }
      });

      // Pull in the next result (if any)
      match = regex.exec(output);
    }

    return messages;
  }
開發者ID:AtomLinter,項目名稱:linter-swiftlint,代碼行數:83,代碼來源:linter-provider.ts


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