From 26aac69a5c4c33e08acbcdd46ffe2f5c554b19e4 Mon Sep 17 00:00:00 2001 From: Alexander Kachkaev Date: Thu, 11 Jan 2018 18:26:06 +0300 Subject: [PATCH] Switch to remark-cli to unlock remark version and support .remarkrc --- CHANGELOG.md | 1 + README.md | 4 +- docs/options.md | 66 ++++++++++++++++++++++++++++++ package.json | 1 - src/beautifiers/remark.coffee | 76 ++++++++++++++++++++++------------- src/languages/markdown.coffee | 4 ++ src/options.json | 30 ++++++++++++++ 7 files changed, 150 insertions(+), 32 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 3284e8d7b..e0066c39c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,5 @@ # Next +- Switch to external [`Remark CLI`](https://github.com/remarkjs/remark/tree/master/packages/remark-cli) and thus allow for user-defined config with `remarkrc` ([#965](https://github.com/Glavin001/atom-beautify/issues/965)) - Fix [#1862](https://github.com/Glavin001/atom-beautify/issues/1862) Add support for ocp-indent as an executable # v0.30.9 (2017-11-22) diff --git a/README.md b/README.md index 040ec4ecd..2523e92e2 100644 --- a/README.md +++ b/README.md @@ -120,7 +120,7 @@ Some of the supported beautifiers are developed for Node.js and are automaticall | Pug Beautify | :white_check_mark: | :ok_hand: Not necessary | :smiley: Nothing! | | puppet-lint | :warning: 1 executable | :white_check_mark: :100:% of executables | :whale: With [Docker](https://www.docker.com/):
1. Install [puppet-lint (`puppet-lint`)](http://puppet-lint.com/) with `docker pull unibeautify/puppet-lint`

:bookmark_tabs: Manually:
1. Install [puppet-lint (`puppet-lint`)](http://puppet-lint.com/) by following http://puppet-lint.com/
| | pybeautifier | :warning: Manual installation | :construction: Not an executable | :page_facing_up: Go to https://github.com/guyskk/pybeautifier and follow the instructions. | -| Remark | :white_check_mark: | :ok_hand: Not necessary | :smiley: Nothing! | +| Remark | :warning: 1 executable | :x: No Docker support | :bookmark_tabs: Manually:
1. Install [Remark CLI (`remark`)](https://github.com/remarkjs/remark) by following https://github.com/remarkjs/remark/tree/master/packages/remark-cli#installation
| | Rubocop | :warning: Manual installation | :construction: Not an executable | :page_facing_up: Go to https://github.com/bbatsov/rubocop and follow the instructions. | | Ruby Beautify | :warning: Manual installation | :construction: Not an executable | :page_facing_up: Go to https://github.com/erniebrodeur/ruby-beautify and follow the instructions. | | rustfmt | :warning: Manual installation | :construction: Not an executable | :page_facing_up: Go to https://github.com/rust-lang-nursery/rustfmt and follow the instructions. | @@ -173,7 +173,7 @@ See [all supported options in the documentation at `docs/options.md`](docs/opti | LaTeX | `BibTeX`, `LaTeX`, `TeX` |`.bib`, `.tex`, `.sty`, `.cls`, `.dtx`, `.ins`, `.bbx`, `.cbx` | **[`Latex Beautify`](https://github.com/cmhughes/latexindent.pl)** | | LESS | `LESS` |`.less` | **[`Pretty Diff`](https://github.com/prettydiff/prettydiff)**, [`CSScomb`](https://github.com/csscomb/csscomb.js) | | Lua | `Lua` |`.lua`, `.ttslua` | **[`Lua beautifier`](https://github.com/Glavin001/atom-beautify/blob/master/src/beautifiers/lua-beautifier/beautifier.coffee)** | -| Markdown | `GitHub Markdown` |`.markdown`, `.md` | **[`Tidy Markdown`](https://github.com/slang800/tidy-markdown)**, [`Remark`](https://github.com/wooorm/remark) | +| Markdown | `GitHub Markdown` |`.markdown`, `.md` | **[`Tidy Markdown`](https://github.com/slang800/tidy-markdown)**, [`Remark`](https://github.com/remarkjs/remark) | | Marko | `Marko` |`.marko` | **[`Marko Beautifier`](https://github.com/marko-js/marko-prettyprint)** | | Mustache | `HTML (Mustache)` |`.mustache` | **[`JS Beautify`](https://github.com/beautify-web/js-beautify)**, [`Pretty Diff`](https://github.com/prettydiff/prettydiff) | | Nginx | `nginx` |`.conf` | **[`Nginx Beautify`](https://github.com/denysvitali/nginxbeautify)** | diff --git a/docs/options.md b/docs/options.md index 0ae28407c..697332834 100644 --- a/docs/options.md +++ b/docs/options.md @@ -368,6 +368,23 @@ Options for puppet-lint executable. 2. Go into *Packages* and search for "*Atom Beautify*" package. 3. Find the option "*puppet-lint*" and change it to your desired configuration. +##### [Remark CLI](#remark-cli) + +**Important**: This option is only configurable from within Atom Beautify's setting panel. + +**Type**: `object` + +**Description**: + +Options for Remark CLI executable. + +**How to Configure** + +1. You can open the [Settings View](https://github.com/atom/settings-view) by navigating to +*Edit > Preferences (Linux)*, *Atom > Preferences (OS X)*, or *File > Preferences (Windows)*. +2. Go into *Packages* and search for "*Atom Beautify*" package. +3. Find the option "*Remark CLI*" and change it to your desired configuration. + ##### [Rscript](#rscript) **Important**: This option is only configurable from within Atom Beautify's setting panel. @@ -8045,6 +8062,7 @@ Override EOL from line-ending-selector (Supported by Lua beautifier) | `beautify_on_save` | :white_check_mark: | :white_check_mark: | | `commonmark` | :white_check_mark: | :x: | | `gfm` | :white_check_mark: | :x: | +| `search_for_configuration` | :white_check_mark: | :x: | | `yaml` | :white_check_mark: | :x: | **Description**: @@ -8156,6 +8174,30 @@ GitHub Flavoured Markdown (Supported by Remark) } ``` +##### [Search for configuration](#search-for-configuration) + +**Namespace**: `markdown` + +**Key**: `search_for_configuration` + +**Type**: `boolean` + +**Supported Beautifiers**: [`Remark`](#remark) + +**Description**: + +Searches for `remarkrc` file and respects rules in it. If set, **Commonmark**, **Gfm** and **Yaml** options are ignored (Supported by Remark) + +**Example `.jsbeautifyrc` Configuration** + +```json +{ + "markdown": { + "search_for_configuration": false + } +} +``` + ##### [Yaml](#yaml) **Namespace**: `markdown` @@ -18620,6 +18662,30 @@ Allows and disallows several constructs. (Supported by Remark) } ``` +##### [Search for configuration](#search-for-configuration) + +**Namespace**: `markdown` + +**Key**: `search_for_configuration` + +**Type**: `boolean` + +**Supported Beautifiers**: [`Remark`](#remark) + +**Description**: + +Searches for `remarkrc` file and respects rules in it. If set, **Commonmark**, **Gfm** and **Yaml** options are ignored (Supported by Remark) + +**Example `.jsbeautifyrc` Configuration** + +```json +{ + "markdown": { + "search_for_configuration": false + } +} +``` + ### Rubocop diff --git a/package.json b/package.json index 8898cdd74..aa4f07cc2 100644 --- a/package.json +++ b/package.json @@ -185,7 +185,6 @@ "open": "0.0.5", "prettydiff2": "^2.2.7", "pug-beautify": "^0.1.1", - "remark": "6.0.1", "season": "6.0.0", "semver": "^5.3.0", "shell-env": "^0.3.0", diff --git a/src/beautifiers/remark.coffee b/src/beautifiers/remark.coffee index 2f34ca9c8..e4ba85dc1 100644 --- a/src/beautifiers/remark.coffee +++ b/src/beautifiers/remark.coffee @@ -1,44 +1,62 @@ +### +Requires https://github.com/remarkjs/remark +### "use strict" Beautifier = require('./beautifier') module.exports = class Remark extends Beautifier name: "Remark" - link: "https://github.com/wooorm/remark" + link: "https://github.com/remarkjs/remark" options: { _: { gfm: true yaml: true commonmark: true - footnotes: true - pedantic: true - breaks: true - entities: true - setext: true - closeAtx: true - looseTable: true - spacedTable: true - fence: true - fences: true - bullet: true - listItemIndent: true - incrementListMarker: true - rule: true - ruleRepetition: true - ruleSpaces: true - strong: true - emphasis: true - position: true + search_for_configuration: true } Markdown: true } - beautify: (text, language, options) -> - return new @Promise((resolve, reject) -> - try - remark = require 'remark' - cleanMarkdown = remark().process(text, options).toString() - resolve cleanMarkdown - catch err - @error("Remark error: #{err}") - reject(err) + executables: [ + { + name: "Remark CLI" + cmd: "remark" + homepage: "https://github.com/remarkjs/remark" + installation: "https://github.com/remarkjs/remark/tree/master/packages/remark-cli#installation" + version: { + parse: (text) -> + return text.match(/remark: (\d+\.\d+\.\d+)/)[1] + runOptions: { + returnStderr: true + } + } + } + ] + + beautify: (text, language, options, context) -> + cwd = context.filePath and path.dirname context.filePath + remarkArgs = [ + '--no-color' + '--no-ignore' + '--file-path' + context.filePath + ] + remarkOptions = {} + + if (!options.search_for_configuration) + settings = Object.assign({}, options) + delete settings.search_for_configuration + serializedSettings = JSON.stringify(settings).slice(1, -1) + remarkArgs.push('--no-config', '--setting', serializedSettings) + + return new Promise((resolve, reject) => + @exe("remark") + .run(remarkArgs, { + cwd + onStdin: (stdin) -> + stdin.end text + }) + .then (output) -> + resolve(output) + .catch(reject) ) diff --git a/src/languages/markdown.coffee b/src/languages/markdown.coffee index 2f6aaea88..49aed82b0 100644 --- a/src/languages/markdown.coffee +++ b/src/languages/markdown.coffee @@ -33,4 +33,8 @@ module.exports = { type: 'boolean' default: false description: 'Allows and disallows several constructs.' + search_for_configuration: + type: 'boolean' + default: false + description: 'Searches for `remarkrc` file and respects rules in it. If set, **Commonmark**, **Gfm** and **Yaml** options are ignored' } diff --git a/src/options.json b/src/options.json index 35bda1b67..6cebd44d7 100644 --- a/src/options.json +++ b/src/options.json @@ -4686,6 +4686,20 @@ "namespace": "markdown" } }, + "search_for_configuration": { + "type": "boolean", + "default": false, + "description": "Searches for `remarkrc` file and respects rules in it. If set, **Commonmark**, **Gfm** and **Yaml** options are ignored (Supported by Remark)", + "title": "Search for configuration", + "beautifiers": [ + "Remark" + ], + "key": "search_for_configuration", + "language": { + "name": "Markdown", + "namespace": "markdown" + } + }, "disabled": { "title": "Disable Beautifying Language", "order": -3, @@ -9400,6 +9414,22 @@ } } }, + "remark": { + "key": "remark", + "title": "Remark CLI", + "type": "object", + "collapsed": true, + "description": "Options for Remark CLI executable.", + "properties": { + "path": { + "key": "path", + "title": "Binary/Script Path", + "type": "string", + "default": "", + "description": "Absolute path to the \"remark\" executable's binary/script." + } + } + }, "sass-convert": { "key": "sass-convert", "title": "SassConvert",