git subrepo clone (merge) https://github.com/prettier/vim-prettier.git ./dotfiles/.vim/plugged/vim-prettier

subrepo:
  subdir:   "dotfiles/.vim/plugged/vim-prettier"
  merged:   "5e6cca21"
upstream:
  origin:   "https://github.com/prettier/vim-prettier.git"
  branch:   "master"
  commit:   "5e6cca21"
git-subrepo:
  version:  "0.4.3"
  origin:   "???"
  commit:   "???"
This commit is contained in:
Git E2E Dev Test Username 2022-10-18 10:36:42 -04:00
parent f7b1840547
commit a8e788a215
77 changed files with 6370 additions and 0 deletions

View file

@ -0,0 +1,12 @@
**Do you want to request a *feature* or report a *bug*?**
**What is the current/expected behavior?**
**What version of `vim-prettier` are you using - (output of `:PrettierVersion`) ?**
**What version of `prettier` are you using - (output of `:PrettierCliVersion`) ?**
**What is your `prettier` executable path - (output of `:PrettierCliPath`) ?**
**Did this work in previous versions of vim-prettier and/or prettier ?**

View file

@ -0,0 +1,19 @@
*Before* submitting a pull request, please make sure the following is done...
1. Fork the repo and create your branch from `master`.
2. If you've added code that should be tested, do a sanity check on `vim8` and `neovim`
3. If you've changed APIs, update the README and documentation `./doc/prettier.txt`
Please use the simple form below as a guideline for describing your pull request.
Thanks for contributing to vim-prettier
* * *
**Summary**
[...]
**Test Plan**
[...]

View file

@ -0,0 +1,5 @@
TODO
doc/tags
node_modules
.yarn_lock
yarn.lock

View file

@ -0,0 +1,12 @@
; DO NOT EDIT (unless you know what you are doing)
;
; This subdirectory is a git "subrepo", and this file is maintained by the
; git-subrepo command. See https://github.com/git-commands/git-subrepo#readme
;
[subrepo]
remote = https://github.com/prettier/vim-prettier.git
branch = master
commit = 5e6cca21e12587c02e32a06bf423519eb1e9f1b2
parent = f7b18405477e3cefcddf9d52b26321adf719f361
method = merge
cmdver = 0.4.3

View file

@ -0,0 +1,537 @@
# Changelog
## [1.0.0-beta](https://github.com/prettier/vim-prettier/tree/1.0.0-beta) (2020-09-07)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/1.0.0-alpha...1.0.0-beta)
**Implemented enhancements:**
- Toggle autoformat feature and/or documentation [\#170](https://github.com/prettier/vim-prettier/issues/170)
- 1.0 release [\#126](https://github.com/prettier/vim-prettier/issues/126)
**Fixed bugs:**
- formatting by saving works only for languages of last opened file [\#185](https://github.com/prettier/vim-prettier/issues/185)
- bugfix/issue-229-fixing-neovim-0-4-compatibility [\#231](https://github.com/prettier/vim-prettier/pull/231) ([mitermayer](https://github.com/mitermayer))
**Closed issues:**
- Support prettier-stylelint [\#255](https://github.com/prettier/vim-prettier/issues/255)
- Autoformat on save does not work on yaml files [\#245](https://github.com/prettier/vim-prettier/issues/245)
- PrettierFragment not work [\#241](https://github.com/prettier/vim-prettier/issues/241)
- Error when running :Prettier on gvim [\#240](https://github.com/prettier/vim-prettier/issues/240)
- Installation fails in post-update hook using vim plug [\#237](https://github.com/prettier/vim-prettier/issues/237)
- `autoformat\_config\_present` does not re-evaluate the presence of the prettier config file after vim is started [\#233](https://github.com/prettier/vim-prettier/issues/233)
- Add support for `prettier 2.x` [\#232](https://github.com/prettier/vim-prettier/issues/232)
- PrettierAsync moves cursor to top of buffer [\#229](https://github.com/prettier/vim-prettier/issues/229)
- Autoformatting Stops Working [\#228](https://github.com/prettier/vim-prettier/issues/228)
- /\* prettier-ignore \*/ inside CSS file not working [\#227](https://github.com/prettier/vim-prettier/issues/227)
- How do I run prettier for markdown files for Hugo the static site generator? [\#223](https://github.com/prettier/vim-prettier/issues/223)
- Package.json configuration not loaded properly \(release 1.x\) [\#221](https://github.com/prettier/vim-prettier/issues/221)
- TypeScript is formatted as PHP \(1.x\) [\#219](https://github.com/prettier/vim-prettier/issues/219)
- How configure [\#218](https://github.com/prettier/vim-prettier/issues/218)
- Error on `:wq` [\#215](https://github.com/prettier/vim-prettier/issues/215)
- Bug: failed to parse buffer. [\#214](https://github.com/prettier/vim-prettier/issues/214)
- release/1.x: prettier plugins do not work when installed with pnpm [\#211](https://github.com/prettier/vim-prettier/issues/211)
- .prettierignore appends a bunch of nonsense [\#189](https://github.com/prettier/vim-prettier/issues/189)
- Failed to parse buffer import.meta.url [\#188](https://github.com/prettier/vim-prettier/issues/188)
- Document how to add q-args [\#168](https://github.com/prettier/vim-prettier/issues/168)
- Document how to add custom extensions [\#167](https://github.com/prettier/vim-prettier/issues/167)
- styling over scp [\#149](https://github.com/prettier/vim-prettier/issues/149)
**Merged pull requests:**
- Uses default cli configs [\#260](https://github.com/prettier/vim-prettier/pull/260) ([ethan605](https://github.com/ethan605))
- Add buffer-level prettier exec command to doc [\#259](https://github.com/prettier/vim-prettier/pull/259) ([jsit](https://github.com/jsit))
- Add support for buffer-level prettier\_exec\_cmd, for prettier-stylelint for instance [\#256](https://github.com/prettier/vim-prettier/pull/256) ([jsit](https://github.com/jsit))
- Bump acorn from 5.7.3 to 5.7.4 [\#254](https://github.com/prettier/vim-prettier/pull/254) ([dependabot[bot]](https://github.com/apps/dependabot))
- Bump lodash from 4.17.15 to 4.17.19 [\#253](https://github.com/prettier/vim-prettier/pull/253) ([dependabot[bot]](https://github.com/apps/dependabot))
- Fix error when quitting Neovim with :wq [\#252](https://github.com/prettier/vim-prettier/pull/252) ([mrnugget](https://github.com/mrnugget))
- Add missing ".yml" in autocmd [\#246](https://github.com/prettier/vim-prettier/pull/246) ([raxell](https://github.com/raxell))
- Fix string concatenation typo [\#243](https://github.com/prettier/vim-prettier/pull/243) ([coolreader18](https://github.com/coolreader18))
- issue/232-adding-support-for-prettier-2.x - Adding support for prettier 2x [\#238](https://github.com/prettier/vim-prettier/pull/238) ([mitermayer](https://github.com/mitermayer))
- Add instructions for installing with vim 8+ [\#236](https://github.com/prettier/vim-prettier/pull/236) ([coolaj86](https://github.com/coolaj86))
- Autoformat .rb files [\#235](https://github.com/prettier/vim-prettier/pull/235) ([jamesbvaughan](https://github.com/jamesbvaughan))
- Force reevaluation of autoformat settings at buffer write time [\#234](https://github.com/prettier/vim-prettier/pull/234) ([cjlarose](https://github.com/cjlarose))
- Fix readme to properly reflect how to downgrade [\#225](https://github.com/prettier/vim-prettier/pull/225) ([ParamagicDev](https://github.com/ParamagicDev))
- New option: prettier\#autoformat\_require\_pragma [\#224](https://github.com/prettier/vim-prettier/pull/224) ([simnalamburt](https://github.com/simnalamburt))
## [1.0.0-alpha](https://github.com/prettier/vim-prettier/tree/1.0.0-alpha) (2020-02-05)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.7...1.0.0-alpha)
**Implemented enhancements:**
- Add A "Close Empty JSX Element" Option Like On VS Code's Prettier [\#202](https://github.com/prettier/vim-prettier/issues/202)
- Support custom prettier plugins [\#119](https://github.com/prettier/vim-prettier/issues/119)
- Add support for neovim async [\#99](https://github.com/prettier/vim-prettier/issues/99)
- Formatting with visual selection doesn't respect indentation [\#75](https://github.com/prettier/vim-prettier/issues/75)
- Using prettier-eslint-cli [\#42](https://github.com/prettier/vim-prettier/issues/42)
- Support for 'prettier-standard-formatter' [\#20](https://github.com/prettier/vim-prettier/issues/20)
**Fixed bugs:**
- First undo after :Prettier takes me to the top of the file [\#184](https://github.com/prettier/vim-prettier/issues/184)
- Vim-prettier doesn't use project config [\#162](https://github.com/prettier/vim-prettier/issues/162)
- Error infinite loop Prettier: failed to parse buffer [\#113](https://github.com/prettier/vim-prettier/issues/113)
- vim-prettier not working when editing files that have white spaces on its path [\#108](https://github.com/prettier/vim-prettier/issues/108)
**Closed issues:**
- Bug: Bracket spacing is ignored [\#222](https://github.com/prettier/vim-prettier/issues/222)
- E121: Undefined variable: g:prettier\#autoformat [\#216](https://github.com/prettier/vim-prettier/issues/216)
- Plugin should load project config if available [\#213](https://github.com/prettier/vim-prettier/issues/213)
- incosistent with prettier cli and introducing syntaxt error. [\#200](https://github.com/prettier/vim-prettier/issues/200)
- For "in-memory" buffers \(not saved to file system\): `Prettier: failed to parse buffer` [\#199](https://github.com/prettier/vim-prettier/issues/199)
- Loading global .prettierrc from user's home ? [\#197](https://github.com/prettier/vim-prettier/issues/197)
- Can I automatically disable vim-prettier if .prettierrc is doesn't exists in project folder? [\#195](https://github.com/prettier/vim-prettier/issues/195)
- make prettier respect eslint [\#194](https://github.com/prettier/vim-prettier/issues/194)
- Window is unexpectedly scrolled after :Prettier [\#192](https://github.com/prettier/vim-prettier/issues/192)
- Autoformat not working on save [\#191](https://github.com/prettier/vim-prettier/issues/191)
- fail to parse buffer? [\#187](https://github.com/prettier/vim-prettier/issues/187)
- Wrong parser used for markdown files [\#186](https://github.com/prettier/vim-prettier/issues/186)
- No syntax color for html files when vim-prettier is enabled [\#183](https://github.com/prettier/vim-prettier/issues/183)
- Error detected while processing BufWrite Auto commands for "\*.rb" [\#180](https://github.com/prettier/vim-prettier/issues/180)
- Calling Prettier error if project contains prettier configuration [\#178](https://github.com/prettier/vim-prettier/issues/178)
- add groovy handling [\#177](https://github.com/prettier/vim-prettier/issues/177)
- on run :Prettier command weird characters added at the beginning of the file [\#174](https://github.com/prettier/vim-prettier/issues/174)
- Support prettier/prettier-ruby [\#172](https://github.com/prettier/vim-prettier/issues/172)
- vim-prettier clobbering markdown files [\#166](https://github.com/prettier/vim-prettier/issues/166)
- How to not always auto format by default [\#164](https://github.com/prettier/vim-prettier/issues/164)
- `E121: Undefined variable: g:prettier\#autoformat` when executing `vi` [\#161](https://github.com/prettier/vim-prettier/issues/161)
- Error parsing Typescript [\#153](https://github.com/prettier/vim-prettier/issues/153)
- Restarting development from today [\#152](https://github.com/prettier/vim-prettier/issues/152)
- Unexpected cursor movement [\#151](https://github.com/prettier/vim-prettier/issues/151)
- Adding support for lint tools custom executables after prettier \(like lint-staged\) [\#148](https://github.com/prettier/vim-prettier/issues/148)
- Prettier: failed to parse buffer. [\#147](https://github.com/prettier/vim-prettier/issues/147)
- my config single\_quote is ignored [\#146](https://github.com/prettier/vim-prettier/issues/146)
- Prettier: failed to parse buffer. [\#145](https://github.com/prettier/vim-prettier/issues/145)
- Prettier throws an invalid expression ' --print-width ' when I run in vim [\#143](https://github.com/prettier/vim-prettier/issues/143)
- Re-enable .editorconfig support [\#141](https://github.com/prettier/vim-prettier/issues/141)
- saving a file ignored in .prettierignore outputs part of the file back to the buffer [\#140](https://github.com/prettier/vim-prettier/issues/140)
- Prettierrc support/default usage [\#137](https://github.com/prettier/vim-prettier/issues/137)
- Update DOC's and README [\#106](https://github.com/prettier/vim-prettier/issues/106)
**Merged pull requests:**
- Use `get\(\)` to check `g:prettier\#autoformat` safely in ftplugin [\#217](https://github.com/prettier/vim-prettier/pull/217) ([hankchiutw](https://github.com/hankchiutw))
- Toggle the autoformat setting based on config file presence. [\#212](https://github.com/prettier/vim-prettier/pull/212) ([atomdmac](https://github.com/atomdmac))
- making-auto-format-disabled-by-default - Making autoformat disabled by [\#208](https://github.com/prettier/vim-prettier/pull/208) ([mitermayer](https://github.com/mitermayer))
- Issues/184 fixing undo step [\#207](https://github.com/prettier/vim-prettier/pull/207) ([mitermayer](https://github.com/mitermayer))
- Adding support for require-pragma and depracting previous naive implemenation [\#206](https://github.com/prettier/vim-prettier/pull/206) ([mitermayer](https://github.com/mitermayer))
- moving-build-to-make-file - Adding build file [\#203](https://github.com/prettier/vim-prettier/pull/203) ([mitermayer](https://github.com/mitermayer))
- enabling-tests-on-ci - Enabling tests as part of the CI run [\#201](https://github.com/prettier/vim-prettier/pull/201) ([mitermayer](https://github.com/mitermayer))
- updating-travis-to-use-docker - Moving to use vint from docker image [\#198](https://github.com/prettier/vim-prettier/pull/198) ([mitermayer](https://github.com/mitermayer))
- Shore/master rebasing [\#196](https://github.com/prettier/vim-prettier/pull/196) ([mitermayer](https://github.com/mitermayer))
- Added some file extensions [\#193](https://github.com/prettier/vim-prettier/pull/193) ([hrkw00](https://github.com/hrkw00))
- improve Requirement's message clearness [\#190](https://github.com/prettier/vim-prettier/pull/190) ([jonathan-soifer](https://github.com/jonathan-soifer))
- Ignore generated help tags file [\#181](https://github.com/prettier/vim-prettier/pull/181) ([mikesep](https://github.com/mikesep))
- Fix README markdown. [\#179](https://github.com/prettier/vim-prettier/pull/179) ([Onra](https://github.com/Onra))
- Integrating vim driver [\#176](https://github.com/prettier/vim-prettier/pull/176) ([mitermayer](https://github.com/mitermayer))
- Release/1.x [\#175](https://github.com/prettier/vim-prettier/pull/175) ([mitermayer](https://github.com/mitermayer))
- Make markdown check more resilient [\#173](https://github.com/prettier/vim-prettier/pull/173) ([rivertam](https://github.com/rivertam))
- Fix markdown mangling issue [\#169](https://github.com/prettier/vim-prettier/pull/169) ([rivertam](https://github.com/rivertam))
- Add option for html whitespace sensitivity [\#165](https://github.com/prettier/vim-prettier/pull/165) ([dewyze](https://github.com/dewyze))
- Handle file paths with whitespace [\#163](https://github.com/prettier/vim-prettier/pull/163) ([jason0x43](https://github.com/jason0x43))
- Set default "config\_precendence" to "file-override" [\#160](https://github.com/prettier/vim-prettier/pull/160) ([shuLhan](https://github.com/shuLhan))
- Added html support using the latest prettier 1.15 version [\#159](https://github.com/prettier/vim-prettier/pull/159) ([premithk](https://github.com/premithk))
- space for --use-tabs [\#158](https://github.com/prettier/vim-prettier/pull/158) ([andreiglingeanu](https://github.com/andreiglingeanu))
- On python3.6 we dont need those extra pip deps to be declared [\#157](https://github.com/prettier/vim-prettier/pull/157) ([mitermayer](https://github.com/mitermayer))
- Fixing linting rules [\#156](https://github.com/prettier/vim-prettier/pull/156) ([mitermayer](https://github.com/mitermayer))
- Rebasing vim-prettier plugin Pull Request 120 to 1.0 branch [\#155](https://github.com/prettier/vim-prettier/pull/155) ([mitermayer](https://github.com/mitermayer))
- Add YAML support [\#150](https://github.com/prettier/vim-prettier/pull/150) ([bracki](https://github.com/bracki))
- Enable the default editorconfig support again [\#144](https://github.com/prettier/vim-prettier/pull/144) ([oskarrough](https://github.com/oskarrough))
- Fix PrettierAsync ignored file contents mangling [\#142](https://github.com/prettier/vim-prettier/pull/142) ([SamHowie](https://github.com/SamHowie))
- Remove wrong comment on README.md comment example [\#139](https://github.com/prettier/vim-prettier/pull/139) ([vieiralucas](https://github.com/vieiralucas))
- use buffered mode for neovim job [\#136](https://github.com/prettier/vim-prettier/pull/136) ([chemzqm](https://github.com/chemzqm))
- Start using prettier default arguments [\#130](https://github.com/prettier/vim-prettier/pull/130) ([docwhat](https://github.com/docwhat))
## [0.2.7](https://github.com/prettier/vim-prettier/tree/0.2.7) (2018-05-25)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.6...0.2.7)
**Fixed bugs:**
- Vim crashes with segmentation fault with PrettierAsync [\#135](https://github.com/prettier/vim-prettier/issues/135)
- Deletes file contents of files ignored by .prettierignore [\#92](https://github.com/prettier/vim-prettier/issues/92)
**Closed issues:**
- Upgraded to Node v10 - Pretter:Failed to parse buffer [\#134](https://github.com/prettier/vim-prettier/issues/134)
- \<Plug\>\(Prettier\) doesn't work [\#132](https://github.com/prettier/vim-prettier/issues/132)
- Caught deadly signal SEGV when :PrettierAsync with large file [\#128](https://github.com/prettier/vim-prettier/issues/128)
- bash: no job control in this shell [\#123](https://github.com/prettier/vim-prettier/issues/123)
- Support for language-specific settings [\#121](https://github.com/prettier/vim-prettier/issues/121)
- Can't spot why prettier fails to parse css: "1 col 6| Unexpected token, expected ;" [\#118](https://github.com/prettier/vim-prettier/issues/118)
- Is there a prettier.eslintIntegration config [\#117](https://github.com/prettier/vim-prettier/issues/117)
- Format without saving [\#116](https://github.com/prettier/vim-prettier/issues/116)
- Error on autosave [\#114](https://github.com/prettier/vim-prettier/issues/114)
- Use prettier config for formatting rules [\#112](https://github.com/prettier/vim-prettier/issues/112)
- Unexpected token @ [\#109](https://github.com/prettier/vim-prettier/issues/109)
- Overwrite default configs patterns not found [\#102](https://github.com/prettier/vim-prettier/issues/102)
- Ignored unknown options appearing at top of file [\#100](https://github.com/prettier/vim-prettier/issues/100)
- Neovim unstable async formatting bugs [\#96](https://github.com/prettier/vim-prettier/issues/96)
- How do I enable trailing commas? [\#95](https://github.com/prettier/vim-prettier/issues/95)
- Ignoring unknown option --loglevel, --no-editorconfig and --config-precedence [\#89](https://github.com/prettier/vim-prettier/issues/89)
- Override for proseWrap option [\#88](https://github.com/prettier/vim-prettier/issues/88)
**Merged pull requests:**
- Fix PrettierAsync segmentation fault [\#138](https://github.com/prettier/vim-prettier/pull/138) ([SamHowie](https://github.com/SamHowie))
- Adding discord link [\#131](https://github.com/prettier/vim-prettier/pull/131) ([mitermayer](https://github.com/mitermayer))
- git: ignore unix yarn.lock file [\#129](https://github.com/prettier/vim-prettier/pull/129) ([docwhat](https://github.com/docwhat))
- Amend syntax in documentation around config overrides [\#127](https://github.com/prettier/vim-prettier/pull/127) ([chris-kobrzak](https://github.com/chris-kobrzak))
- Updating the logic for controlling the quickfix flag [\#125](https://github.com/prettier/vim-prettier/pull/125) ([mitermayer](https://github.com/mitermayer))
- doc: typo for quickfix option [\#124](https://github.com/prettier/vim-prettier/pull/124) ([docwhat](https://github.com/docwhat))
- don't change focus to the quicklist [\#122](https://github.com/prettier/vim-prettier/pull/122) ([docwhat](https://github.com/docwhat))
- Fix space in autocmd breaking autosave [\#115](https://github.com/prettier/vim-prettier/pull/115) ([LinuCC](https://github.com/LinuCC))
- Fixing empty spaces directory for async [\#111](https://github.com/prettier/vim-prettier/pull/111) ([mitermayer](https://github.com/mitermayer))
- Fix \#108 spaces in executable path problem [\#110](https://github.com/prettier/vim-prettier/pull/110) ([nelsyeung](https://github.com/nelsyeung))
- Updating docs with vue support reference [\#107](https://github.com/prettier/vim-prettier/pull/107) ([mitermayer](https://github.com/mitermayer))
- Adding vue file detect [\#105](https://github.com/prettier/vim-prettier/pull/105) ([mitermayer](https://github.com/mitermayer))
- Bumping prettier dependencie to 1.10.2 [\#104](https://github.com/prettier/vim-prettier/pull/104) ([mitermayer](https://github.com/mitermayer))
- Add vue file format to README [\#103](https://github.com/prettier/vim-prettier/pull/103) ([corburn](https://github.com/corburn))
- Support the `--arrow-parens` configuration option [\#101](https://github.com/prettier/vim-prettier/pull/101) ([nthurow](https://github.com/nthurow))
- Disabling nvim async by default under feature flag [\#98](https://github.com/prettier/vim-prettier/pull/98) ([mitermayer](https://github.com/mitermayer))
- Fixing lint [\#97](https://github.com/prettier/vim-prettier/pull/97) ([mitermayer](https://github.com/mitermayer))
- Add default option values from Prettier for configuration [\#94](https://github.com/prettier/vim-prettier/pull/94) ([maurobringolf](https://github.com/maurobringolf))
- bugfix - making sure we do not replace content with empty buffer [\#93](https://github.com/prettier/vim-prettier/pull/93) ([mitermayer](https://github.com/mitermayer))
- fix typo in pathogen install method [\#91](https://github.com/prettier/vim-prettier/pull/91) ([nicoder](https://github.com/nicoder))
- Add --prose-wrap option [\#90](https://github.com/prettier/vim-prettier/pull/90) ([frankychung](https://github.com/frankychung))
- Just a simple documentation for vim-pathogen [\#87](https://github.com/prettier/vim-prettier/pull/87) ([gustavo-gimenez](https://github.com/gustavo-gimenez))
- Add async support for neovim [\#81](https://github.com/prettier/vim-prettier/pull/81) ([chemzqm](https://github.com/chemzqm))
## [0.2.6](https://github.com/prettier/vim-prettier/tree/0.2.6) (2017-12-08)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.5...0.2.6)
**Closed issues:**
- Single quote option not working [\#84](https://github.com/prettier/vim-prettier/issues/84)
- no semicolon not working [\#83](https://github.com/prettier/vim-prettier/issues/83)
- Slow [\#82](https://github.com/prettier/vim-prettier/issues/82)
**Merged pull requests:**
- Bumping prettier dep to 1.9.1 [\#86](https://github.com/prettier/vim-prettier/pull/86) ([mitermayer](https://github.com/mitermayer))
- issues-83-and-84 - Fixing prettier 1.9 regression [\#85](https://github.com/prettier/vim-prettier/pull/85) ([mitermayer](https://github.com/mitermayer))
## [0.2.5](https://github.com/prettier/vim-prettier/tree/0.2.5) (2017-11-08)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.4...0.2.5)
**Implemented enhancements:**
- Add support for prettier 1.8 [\#77](https://github.com/prettier/vim-prettier/issues/77)
**Fixed bugs:**
- Prettier: failed to parse buffer. Prettier fails on css files. [\#76](https://github.com/prettier/vim-prettier/issues/76)
**Closed issues:**
- prepends `Ignored unknown option: --config-precedence` in buffer [\#73](https://github.com/prettier/vim-prettier/issues/73)
**Merged pull requests:**
- Issue 77/adding support for prettier 1.8 [\#80](https://github.com/prettier/vim-prettier/pull/80) ([mitermayer](https://github.com/mitermayer))
- issues/76 - the shellescapping util function was breaking async [\#79](https://github.com/prettier/vim-prettier/pull/79) ([mitermayer](https://github.com/mitermayer))
- Add shellescape for file path [\#74](https://github.com/prettier/vim-prettier/pull/74) ([chemzqm](https://github.com/chemzqm))
## [0.2.4](https://github.com/prettier/vim-prettier/tree/0.2.4) (2017-10-20)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.3...0.2.4)
**Implemented enhancements:**
- No references to getting help or support [\#67](https://github.com/prettier/vim-prettier/issues/67)
**Fixed bugs:**
- Incorrect resolving of prettier config [\#71](https://github.com/prettier/vim-prettier/issues/71)
**Closed issues:**
- SyntaxError: Unexpected token [\#69](https://github.com/prettier/vim-prettier/issues/69)
**Merged pull requests:**
- Fixing bug where config was not being correctly loaded based on file [\#72](https://github.com/prettier/vim-prettier/pull/72) ([mitermayer](https://github.com/mitermayer))
- Including extra information on the autoload header and doc header [\#70](https://github.com/prettier/vim-prettier/pull/70) ([mitermayer](https://github.com/mitermayer))
## [0.2.3](https://github.com/prettier/vim-prettier/tree/0.2.3) (2017-10-08)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.2...0.2.3)
**Merged pull requests:**
- adding suppor for vim8 versions older than 8.0.0015 to use async job API [\#66](https://github.com/prettier/vim-prettier/pull/66) ([mitermayer](https://github.com/mitermayer))
## [0.2.2](https://github.com/prettier/vim-prettier/tree/0.2.2) (2017-10-07)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.1...0.2.2)
**Merged pull requests:**
- Making sure we can still save the results of last prettier async run on [\#65](https://github.com/prettier/vim-prettier/pull/65) ([mitermayer](https://github.com/mitermayer))
## [0.2.1](https://github.com/prettier/vim-prettier/tree/0.2.1) (2017-10-07)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.2.0...0.2.1)
**Fixed bugs:**
- Overwrites Buffer1 with contents of Buffer2 [\#62](https://github.com/prettier/vim-prettier/issues/62)
- Confused by file type overrides [\#60](https://github.com/prettier/vim-prettier/issues/60)
**Merged pull requests:**
- bugfix: Fixing auto command params to use extensions instead of magic [\#64](https://github.com/prettier/vim-prettier/pull/64) ([mitermayer](https://github.com/mitermayer))
- bugfix: fixing race condition incorrect buffer formating [\#63](https://github.com/prettier/vim-prettier/pull/63) ([mitermayer](https://github.com/mitermayer))
## [0.2.0](https://github.com/prettier/vim-prettier/tree/0.2.0) (2017-10-04)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.1.3...0.2.0)
**Fixed bugs:**
- `--parser` with value `postcss` is deprecated [\#59](https://github.com/prettier/vim-prettier/issues/59)
**Merged pull requests:**
- bug: Fixing config overwrite value for non js by levaraging --stdin-f… [\#61](https://github.com/prettier/vim-prettier/pull/61) ([mitermayer](https://github.com/mitermayer))
## [0.1.3](https://github.com/prettier/vim-prettier/tree/0.1.3) (2017-09-30)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.1.2...0.1.3)
## [0.1.2](https://github.com/prettier/vim-prettier/tree/0.1.2) (2017-09-26)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.1.1...0.1.2)
**Implemented enhancements:**
- Allow configuration to set lookup path for `prettier` cli on `.vimrc` [\#56](https://github.com/prettier/vim-prettier/issues/56)
**Merged pull requests:**
- issue/56 - Allowing user path overwrite configuration [\#57](https://github.com/prettier/vim-prettier/pull/57) ([mitermayer](https://github.com/mitermayer))
- Fixed some typos in the README [\#55](https://github.com/prettier/vim-prettier/pull/55) ([Haegin](https://github.com/Haegin))
## [0.1.1](https://github.com/prettier/vim-prettier/tree/0.1.1) (2017-09-18)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.1.0...0.1.1)
**Implemented enhancements:**
- Upgrade to support prettier 1.6 [\#51](https://github.com/prettier/vim-prettier/issues/51)
**Merged pull requests:**
- feature: Adding more commands [\#54](https://github.com/prettier/vim-prettier/pull/54) ([mitermayer](https://github.com/mitermayer))
## [0.1.0](https://github.com/prettier/vim-prettier/tree/0.1.0) (2017-09-14)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.15...0.1.0)
**Merged pull requests:**
- Issue/51 adding support for prettier 1.7 [\#52](https://github.com/prettier/vim-prettier/pull/52) ([mitermayer](https://github.com/mitermayer))
## [0.0.15](https://github.com/prettier/vim-prettier/tree/0.0.15) (2017-08-30)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.14...0.0.15)
**Fixed bugs:**
- PrettierAsync does not work on Windows [\#46](https://github.com/prettier/vim-prettier/issues/46)
**Closed issues:**
- :Prettier make cursor history wrong when navigating with \<C-O\> [\#48](https://github.com/prettier/vim-prettier/issues/48)
**Merged pull requests:**
- Making sure that after formatting we preserve in the same line [\#50](https://github.com/prettier/vim-prettier/pull/50) ([mitermayer](https://github.com/mitermayer))
- Added extensions to vim configuration example [\#49](https://github.com/prettier/vim-prettier/pull/49) ([niftylettuce](https://github.com/niftylettuce))
## [0.0.14](https://github.com/prettier/vim-prettier/tree/0.0.14) (2017-08-24)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.13...0.0.14)
**Fixed bugs:**
- :Prettier causes :Ggrep to lose history [\#39](https://github.com/prettier/vim-prettier/issues/39)
**Closed issues:**
- Trailing comma is causing issues with IE10/11 [\#45](https://github.com/prettier/vim-prettier/issues/45)
**Merged pull requests:**
- Async command was not working for windows this patch will make sure it [\#47](https://github.com/prettier/vim-prettier/pull/47) ([mitermayer](https://github.com/mitermayer))
- Add instructions on changing the mapping to README [\#43](https://github.com/prettier/vim-prettier/pull/43) ([eddiezane](https://github.com/eddiezane))
## [0.0.13](https://github.com/prettier/vim-prettier/tree/0.0.13) (2017-08-13)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.12...0.0.13)
**Implemented enhancements:**
- Include changelog [\#35](https://github.com/prettier/vim-prettier/issues/35)
**Merged pull requests:**
- bugfix: should not clear quickfix unless opened by vim-prettier itself [\#40](https://github.com/prettier/vim-prettier/pull/40) ([mitermayer](https://github.com/mitermayer))
## [0.0.12](https://github.com/prettier/vim-prettier/tree/0.0.12) (2017-08-06)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.11...0.0.12)
**Implemented enhancements:**
- Bump internal plugin dependencie to use prettier to 1.5.3 [\#34](https://github.com/prettier/vim-prettier/issues/34)
- Add MIT license [\#33](https://github.com/prettier/vim-prettier/issues/33)
**Closed issues:**
- Unable to disable 'single-quote' [\#32](https://github.com/prettier/vim-prettier/issues/32)
- "failed to parse buffer", but prettier from console works well [\#31](https://github.com/prettier/vim-prettier/issues/31)
- Autoformat "all" files by default. [\#30](https://github.com/prettier/vim-prettier/issues/30)
- Neovim support for job/channel to allow async formatting [\#25](https://github.com/prettier/vim-prettier/issues/25)
**Merged pull requests:**
- Adding changelog file [\#38](https://github.com/prettier/vim-prettier/pull/38) ([mitermayer](https://github.com/mitermayer))
- Adding MIT license [\#37](https://github.com/prettier/vim-prettier/pull/37) ([mitermayer](https://github.com/mitermayer))
- Bumping prettier internal dependencie plugin to 1.5.3 [\#36](https://github.com/prettier/vim-prettier/pull/36) ([mitermayer](https://github.com/mitermayer))
## [0.0.11](https://github.com/prettier/vim-prettier/tree/0.0.11) (2017-07-12)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.10...0.0.11)
**Fixed bugs:**
- Json parser should not include comma at the end [\#26](https://github.com/prettier/vim-prettier/issues/26)
**Merged pull requests:**
- adding-support-for-vim7 - adding support for vim7 [\#29](https://github.com/prettier/vim-prettier/pull/29) ([mitermayer](https://github.com/mitermayer))
## [0.0.10](https://github.com/prettier/vim-prettier/tree/0.0.10) (2017-07-02)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.9...0.0.10)
**Implemented enhancements:**
- should support filetype detection when none is available [\#23](https://github.com/prettier/vim-prettier/issues/23)
**Merged pull requests:**
- bugfix: json parser should not add extra comma to the end [\#27](https://github.com/prettier/vim-prettier/pull/27) ([mitermayer](https://github.com/mitermayer))
## [0.0.9](https://github.com/prettier/vim-prettier/tree/0.0.9) (2017-07-01)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.8...0.0.9)
**Implemented enhancements:**
- bump plugin dependency to prettier 1.5 [\#22](https://github.com/prettier/vim-prettier/issues/22)
- add support for GraphQL parsing [\#21](https://github.com/prettier/vim-prettier/issues/21)
**Merged pull requests:**
- feature/add-filetype-support - Adding filetype detection support when [\#24](https://github.com/prettier/vim-prettier/pull/24) ([mitermayer](https://github.com/mitermayer))
## [0.0.8](https://github.com/prettier/vim-prettier/tree/0.0.8) (2017-06-30)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.7...0.0.8)
**Implemented enhancements:**
- Partial formatting support [\#14](https://github.com/prettier/vim-prettier/issues/14)
**Closed issues:**
- prettier add extra comma at the last parameter of function [\#18](https://github.com/prettier/vim-prettier/issues/18)
**Merged pull requests:**
- Add JSON/GraphQL parser \(prettier 1.5\) [\#17](https://github.com/prettier/vim-prettier/pull/17) ([vutran](https://github.com/vutran))
## [0.0.7](https://github.com/prettier/vim-prettier/tree/0.0.7) (2017-06-20)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.6...0.0.7)
**Merged pull requests:**
- feature: enabling partial buffer conversion [\#15](https://github.com/prettier/vim-prettier/pull/15) ([mitermayer](https://github.com/mitermayer))
- fixed typo [\#13](https://github.com/prettier/vim-prettier/pull/13) ([wangsongiam](https://github.com/wangsongiam))
## [0.0.6](https://github.com/prettier/vim-prettier/tree/0.0.6) (2017-06-07)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.5...0.0.6)
**Merged pull requests:**
- Adding async command and configuration controls [\#12](https://github.com/prettier/vim-prettier/pull/12) ([mitermayer](https://github.com/mitermayer))
## [0.0.5](https://github.com/prettier/vim-prettier/tree/0.0.5) (2017-06-06)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.4...0.0.5)
**Implemented enhancements:**
- Populate quickfix with prettier parsing errors [\#5](https://github.com/prettier/vim-prettier/issues/5)
**Merged pull requests:**
- Bumping support to latest prettier ^1.4.X and enabling support for [\#11](https://github.com/prettier/vim-prettier/pull/11) ([mitermayer](https://github.com/mitermayer))
## [0.0.4](https://github.com/prettier/vim-prettier/tree/0.0.4) (2017-05-31)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.3...0.0.4)
**Fixed bugs:**
- Prettier CLI expects params 'false' instead of 0 [\#9](https://github.com/prettier/vim-prettier/issues/9)
## [0.0.3](https://github.com/prettier/vim-prettier/tree/0.0.3) (2017-05-28)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.2...0.0.3)
**Implemented enhancements:**
- Make the prettier command run async [\#4](https://github.com/prettier/vim-prettier/issues/4)
**Fixed bugs:**
- Fallback plugins not working [\#7](https://github.com/prettier/vim-prettier/issues/7)
**Merged pull requests:**
- Fix default settings [\#16](https://github.com/prettier/vim-prettier/pull/16) ([vutran](https://github.com/vutran))
- Prettier CLI seems to expect 'false' for some parameters instead of 0 [\#10](https://github.com/prettier/vim-prettier/pull/10) ([mitermayer](https://github.com/mitermayer))
- bugfix: fixing bug where prettier installation of the plugin was never [\#8](https://github.com/prettier/vim-prettier/pull/8) ([mitermayer](https://github.com/mitermayer))
- Adding support for async formating and making it default for autosave [\#6](https://github.com/prettier/vim-prettier/pull/6) ([mitermayer](https://github.com/mitermayer))
## [0.0.2](https://github.com/prettier/vim-prettier/tree/0.0.2) (2017-05-26)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/0.0.1...0.0.2)
**Fixed bugs:**
- Should not overwrite buffer when prettier fails to parse file [\#2](https://github.com/prettier/vim-prettier/issues/2)
**Merged pull requests:**
- bugfix: Making sure that when prettier fail to parse buffer we do not [\#3](https://github.com/prettier/vim-prettier/pull/3) ([mitermayer](https://github.com/mitermayer))
- Adding working example GIF [\#1](https://github.com/prettier/vim-prettier/pull/1) ([mitermayer](https://github.com/mitermayer))
## [0.0.1](https://github.com/prettier/vim-prettier/tree/0.0.1) (2017-05-24)
[Full Changelog](https://github.com/prettier/vim-prettier/compare/a53ffa1ba81c76d0b2c29afe55ab131c6cc9a0e3...0.0.1)
\* *This Changelog was automatically generated by [github_changelog_generator](https://github.com/github-changelog-generator/github-changelog-generator)*

View file

@ -0,0 +1,66 @@
FROM alpine:3.8 as builder
WORKDIR /tmp
RUN apk add --no-cache \
build-base \
ctags \
git \
libx11-dev \
libxpm-dev \
libxt-dev \
libxtst-dev \
make \
ncurses-dev \
python3 \
python3-dev \
perl-dev \
ruby-dev
RUN git clone https://github.com/vim/vim && cd vim \
&& ./configure \
--with-features=huge \
--with-x \
--with-compiledby=mitermayer.reis@gmail.com \
&& make install
FROM testbed/vim:latest
COPY --from=builder /usr/local/bin /usr/local/bin
COPY --from=builder /usr/local/share/vim /usr/local/share/vim
# install pip
ENV PACKAGES="\
bash \
git \
ruby \
ruby-dev \
ruby-json \
python \
python3 \
py-pip \
nodejs \
npm \
libxt \
libx11 \
"
RUN apk --update add $PACKAGES && \
rm -rf /var/cache/apk/* /tmp/* /var/tmp/*
# install supported vim8 and neovim
RUN install_vim -tag v7.4.052 -name vim7 -build \
-tag v8.1.0519 -name vim8 -build \
-tag neovim:v0.4.3 -name neovim -build
# set default vim install
RUN cp /vim-build/bin/vim8 /usr/local/bin/vim
# upgrade node and yarn
RUN npm install -g npm yarn
# copy vimrc
ADD tests/vimrc /root/.vimrc
# install vint
RUN pip install typing>=4.6.2 pathlib==1.0.1 enum34>=1.0.4 vim-vint==0.3.19

View file

@ -0,0 +1,7 @@
Copyright 2017 Mitermayer Reis
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

View file

@ -0,0 +1,63 @@
NAME=vim-prettier
VERSION=1.0.0-beta
build:
docker build -t mitermayer/vim-test-bed .
test:
echo "Running tests..."
docker run \
-t \
--rm \
-v ${PWD}:/testplugin \
-v ${PWD}/tests:/home \
"mitermayer/vim-test-bed" \
yarn --cwd testplugin test
test-update-snapshot:
echo "Running tests..."
docker run \
-t \
--rm \
-v ${PWD}:/testplugin \
-v ${PWD}/tests:/home \
"mitermayer/vim-test-bed" \
yarn --cwd testplugin test -u
lint:
echo "Running linter..."
docker run \
-t \
--rm \
-v ${PWD}:/testplugin \
-v ${PWD}/tests:/home \
"mitermayer/vim-test-bed" \
yarn --cwd testplugin lint
tag:
git tag $(VERSION)
chroot:
docker run \
-it \
-v ${PWD}:/testplugin \
-v ${PWD}/tests:/home \
"mitermayer/vim-test-bed" \
bash
run:
docker run \
-it \
-v ${PWD}:/testplugin \
-v ${PWD}/tests:/home \
"mitermayer/vim-test-bed" \
${VIM_VERSION} -u /home/vimrc
changelog:
docker run -it --rm -v "${PWD}":/usr/local/src/your-app ferrarimarco/github-changelog-generator -u prettier -p vim-prettier -t ${GITHUB_REPO_READ_TOKEN}
release:
git push --tags
.PHONY: build test lint tag chroot run changelog release

View file

@ -0,0 +1,287 @@
## vim-prettier
A vim plugin wrapper for prettier, pre-configured with custom default prettier
settings.
---
**NOTE**: If you want to fallback to older version of prettier/vim-prettier please add this to your `.vimrc`:
```vim
Plug 'prettier/vim-prettier', {
\ 'do': 'yarn install --frozen-lockfile --production',
\ 'branch': 'release/0.x'
\ }
```
---
By default it will auto format **javascript**, **typescript**, **less**,
**scss**, **css**, **json**, **graphql** and **markdown** files if they
have/support the "@format" pragma annotation in the header of the file.
![vim-prettier](/media/vim-prettier.gif?raw=true 'vim-prettier')
### INSTALL
To install with vim 8+ plugins, simply clone to your `~/.vim/pack/plugins/start` directory, and add `packloadall` to your `.vimrc` (if you haven't already).
```bash
mkdir -p ~/.vim/pack/plugins/start
git clone https://github.com/prettier/vim-prettier ~/.vim/pack/plugins/start/vim-prettier
```
`.vimrc`:
```vim
packloadall
```
Install with [vim-plug](https://github.com/junegunn/vim-plug), assumes node and
yarn|npm installed globally.
```vim
" post install (yarn install | npm install) then load plugin only for editing supported files
Plug 'prettier/vim-prettier', {
\ 'do': 'yarn install --frozen-lockfile --production',
\ 'for': ['javascript', 'typescript', 'css', 'less', 'scss', 'json', 'graphql', 'markdown', 'vue', 'svelte', 'yaml', 'html'] }
```
or simply enable for all formats by:
```vim
" post install (yarn install | npm install) then load plugin only for editing supported files
Plug 'prettier/vim-prettier', { 'do': 'yarn install --frozen-lockfile --production' }
```
For those using [vim-pathogen](https://github.com/tpope/vim-pathogen), you can run the following in a terminal:
```
cd ~/.vim/bundle
git clone https://github.com/prettier/vim-prettier
```
If using [dein](https://github.com/Shougo/dein.vim), add the following to your dein config:
```vim
call dein#add('prettier/vim-prettier', {'build': 'npm install'})
```
If using other vim plugin managers or doing manual setup make sure to have
`prettier` installed globally or go to your vim-prettier directory and either do
`npm install` or `yarn install --frozen-lockfile`
### Prettier Executable resolution
When installed via vim-plug, a default prettier executable is installed inside
vim-prettier.
vim-prettier executable resolution:
1. Look for user defined prettier cli path from vim configuration file
2. Traverse parents and search for Prettier installation inside `node_modules`
3. Look for a global prettier installation
4. Use locally installed vim-prettier prettier executable
### Prettier Stylelint
To use an alternative command, like
[`prettier-stylelint`](https://github.com/hugomrdias/prettier-stylelint), set
this at the buffer level, e.g.:
```vim
au FileType css,scss let b:prettier_exec_cmd = "prettier-stylelint"
```
vim-prettier will look for the executable in the same places it looks for
`prettier`, and will fall back to `prettier` if it can't find
`b:prettier_exec_cmd`
### USAGE
Prettier by default will run on auto save but can also be manually triggered by:
```vim
<Leader>p
```
or
```vim
:Prettier
```
If your are on vim 8+ you can also trigger async formatting by:
```vim
:PrettierAsync
```
You can send to prettier your entire buffer but ensure that it formats only your selection.
**note:** differs from `:PrettierFragment` by sending the entire buffer to prettier, allowing identation level to be preserved, but it requires the whole file to be valid.
```vim
:PrettierPartial
```
You can send to prettier your current selection as a fragment of same type as the file being edited.
**note:** differs from `:PrettierPartial` by sending only the current selection to prettier, this allows for faster formatting but wont preserve indentation.
```vim
:PrettierFragment
```
You can check what is the `vim-prettier` plugin version by:
```vim
:PrettierVersion
```
You can send commands to the resolved `prettier` cli by:
```
:PrettierCli <q-args>
```
You can check what is the resolved `prettier` cli path by:
```vim
:PrettierCliPath
```
You can check what is the resolved `prettier` cli version by:
```vim
:PrettierCliVersion
```
### Configuration
Change the mapping to run from the default of `<Leader>p`
```vim
nmap <Leader>py <Plug>(Prettier)
```
Enable auto formatting of files that have "@format" or "@prettier" tag
```vim
let g:prettier#autoformat = 1
```
Allow auto formatting for files without "@format" or "@prettier" tag
```vim
let g:prettier#autoformat_require_pragma = 0
```
**NOTE** The previous two options can be used together for autoformatting files on save without `@format` or `@prettier` tags
```vim
let g:prettier#autoformat = 1
let g:prettier#autoformat_require_pragma = 0
```
Toggle the `g:prettier#autoformat` setting based on whether a config file can be found in the current directory or any parent directory. Note that this will override the `g:prettier#autoformat` setting!
```vim
let g:prettier#autoformat_config_present = 1
```
A list containing all config file names to search for when using the `g:prettier#autoformat_config_present` option.
```vim
let g:prettier#autoformat_config_files = [...]
```
Set the prettier CLI executable path
```vim
let g:prettier#exec_cmd_path = "~/path/to/cli/prettier"
```
The command `:Prettier` by default is synchronous but can also be forced async
```vim
let g:prettier#exec_cmd_async = 1
```
By default parsing errors will open the quickfix but can also be disabled
```vim
let g:prettier#quickfix_enabled = 0
```
By default selection formatting will be running `:PrettierFragment` but we can set
`:PrettierPartial` as the default selection formatting by:
```vim
let g:prettier#partial_format=1
```
By default we auto focus on the quickfix when there are errors but can also be disabled
```vim
let g:prettier#quickfix_auto_focus = 0
```
To run vim-prettier not only before saving, but also after changing text or leaving insert mode:
```vim
" when running at every change you may want to disable quickfix
let g:prettier#quickfix_enabled = 0
autocmd TextChanged,InsertLeave *.js,*.jsx,*.mjs,*.ts,*.tsx,*.css,*.less,*.scss,*.json,*.graphql,*.md,*.vue,*.svelte,*.yaml,*.html PrettierAsync
```
### Overwrite default prettier configuration
**Note:** vim-prettier default settings differ from prettier intentionally.
However they can be configured by:
```vim
" Max line length that prettier will wrap on: a number or 'auto' (use
" textwidth).
" default: 'auto'
let g:prettier#config#print_width = 'auto'
" number of spaces per indentation level: a number or 'auto' (use
" softtabstop)
" default: 'auto'
let g:prettier#config#tab_width = 'auto'
" use tabs instead of spaces: true, false, or auto (use the expandtab setting).
" default: 'auto'
let g:prettier#config#use_tabs = 'auto'
" flow|babylon|typescript|css|less|scss|json|graphql|markdown or empty string
" (let prettier choose).
" default: ''
let g:prettier#config#parser = ''
" cli-override|file-override|prefer-file
" default: 'file-override'
let g:prettier#config#config_precedence = 'file-override'
" always|never|preserve
" default: 'preserve'
let g:prettier#config#prose_wrap = 'preserve'
" css|strict|ignore
" default: 'css'
let g:prettier#config#html_whitespace_sensitivity = 'css'
" false|true
" default: 'false'
let g:prettier#config#require_pragma = 'false'
" Define the flavor of line endings
" lf|crlf|cr|all
" defaut: 'lf'
let g:prettier#config#end_of_line = get(g:, 'prettier#config#end_of_line', 'lf')
```
### REQUIREMENT(S)
If the `prettier` executable can't be found by Vim, no code formatting will happen

View file

@ -0,0 +1,98 @@
" vim-prettier: A vim plugin wrapper for prettier, pre-configured with custom default prettier settings.
"
" Script Info {{{
"==========================================================================================================
" Name Of File: prettier.vim
" Description: A vim plugin wrapper for prettier, pre-configured with custom default prettier settings.
" Maintainer: Mitermayer Reis <mitermayer.reis at gmail.com>
" Version: 1.0.0-beta
" Usage: Use :help vim-prettier-usage, or visit https://github.com/prettier/vim-prettier
"
"==========================================================================================================
" }}}
" Displays the resolve prettier CLI path
function! prettier#PrettierCliPath() abort
let l:execCmd = prettier#resolver#executable#getPath()
if l:execCmd != -1
echom l:execCmd
else
call prettier#logging#error#log('EXECUTABLE_NOT_FOUND_ERROR')
endif
endfunction
" Allows user commands to be passed straight to the prettier CLI
function! prettier#PrettierCli(user_input) abort
let l:execCmd = prettier#resolver#executable#getPath()
if l:execCmd != -1
let l:out = system(l:execCmd. ' ' . a:user_input)
echom l:out
else
call prettier#logging#error#log('EXECUTABLE_NOT_FOUND_ERROR')
endif
endfunction
" Allows @format and @prettier pragma support upon saving
function! prettier#Autoformat(...) abort
let l:autoformat = g:prettier#autoformat_config_present ?
\ prettier#IsConfigPresent(g:prettier#autoformat_config_files) :
\ g:prettier#autoformat
if l:autoformat
call prettier#Prettier(1, 1, line('$'), 0, {
\ 'requirePragma': g:prettier#autoformat_require_pragma ? 'true' : 'false'
\ })
endif
endfunction
" Main prettier command
function! prettier#Prettier(...) abort
let l:execCmd = prettier#resolver#executable#getPath()
let l:async = a:0 > 0 ? a:1 : 0
let l:startSelection = a:0 > 1 ? a:2 : 1
let l:endSelection = a:0 > 2 ? a:3 : line('$')
let l:hasSelection = a:0 > 2 ? 1 : 0
let l:partialFormat = a:0 > 3 && a:4 ? a:4 : 0
let l:partialFormatEnabled = l:hasSelection && l:partialFormat
let l:overWrite = a:0 > 4 ? a:5 : {}
let l:bufferConfig = getbufvar(bufnr('%'), 'prettier_ft_default_args', {})
let l:config = extend(l:bufferConfig, l:overWrite)
if l:execCmd != -1
" TODO
" => we should make sure we can resolve --range-start and --range-end when required
" => when the above is required we should also update l:startSelection to '1' and l:endSelection to line('$')
let l:cmd = l:execCmd . prettier#resolver#config#resolve(
\ prettier#resolver#preset#resolve(l:config),
\ l:partialFormatEnabled,
\ l:startSelection,
\ l:endSelection)
" close quickfix if it is opened
call prettier#utils#quickfix#close()
" we will be using portion formatting, so we need to send entire buffer to prettier
if l:partialFormatEnabled
let l:startSelection = 1
let l:endSelection = line('$')
endif
" format buffer
call prettier#job#runner#run(l:cmd, l:startSelection, l:endSelection, l:async)
else
call prettier#logging#error#log('EXECUTABLE_NOT_FOUND_ERROR')
endif
endfunction
" Set autoformat toggle based on whether config file was found.
function! prettier#IsConfigPresent(config_files) abort
for config_file in a:config_files
if filereadable(findfile(config_file, '.;'))
return 1
endif
endfor
return 0
endfunction

View file

@ -0,0 +1,24 @@
" TODO
" this function should just returns the parsed errors list instead
" of opening the quickfix
function! prettier#bridge#parser#onError(out, autoFocus) abort
let l:errors = []
for l:line in a:out
" matches:
" file.ext: SyntaxError: Unexpected token (2:8)sd
" stdin: SyntaxError: Unexpected token (2:8)
" [error] file.ext: SyntaxError: Unexpected token (2:8)
let l:match = matchlist(l:line, '^.*: \(.*\) (\(\d\{1,}\):\(\d\{1,}\)*)')
if !empty(l:match)
call add(l:errors, { 'bufnr': bufnr('%'),
\ 'text': l:match[1],
\ 'lnum': l:match[2],
\ 'col': l:match[3] })
endif
endfor
if len(l:errors)
call prettier#utils#quickfix#open(l:errors, a:autoFocus)
endif
endfunction

View file

@ -0,0 +1,92 @@
let s:prettier_job_running = 0
function! prettier#job#async#neovim#run(cmd, startSelection, endSelection) abort
if s:prettier_job_running == 1
return
endif
let s:prettier_job_running = 1
let l:lines = getline(a:startSelection, a:endSelection)
let l:dict = {
\ 'start': a:startSelection - 1,
\ 'end': a:endSelection,
\ 'buf_nr': bufnr('%'),
\ 'content': l:lines,
\}
let l:out = []
let l:err = []
let l:job = jobstart([&shell, &shellcmdflag, a:cmd], {
\ 'stdout_buffered': 1,
\ 'stderr_buffered': 1,
\ 'on_stdout': {job_id, data, event -> extend(l:out, data)},
\ 'on_stderr': {job_id, data, event -> extend(l:err, data)},
\ 'on_exit': {job_id, status, event -> s:onExit(status, l:dict, l:out, l:err)},
\ })
call jobsend(l:job, l:lines)
call jobclose(l:job, 'stdin')
endfunction
" todo
" Lets refactor this onExit to work similar to our solution for vim8
" at the moment an info json object is been passed with some cached data
" that is than used to do the formatting, its not following the same convetion
" as the vim8 one and is error prone
"
" we should:
"
" 1. make it similar to the vim8 approach
" 2. extract common functionality either above to the runner or to some other module
"
" to test this it rellies on using nvim and having the flag
"
" note that somehow we exectuing both async and sync on nvim when using the autoformat
function! s:onExit(status, info, out, err) abort
if len(a:out) == 0 | return | endif
let l:currentBufferNumber = bufnr('%')
let l:isInsideAnotherBuffer = a:info.buf_nr != l:currentBufferNumber ? 1 : 0
let l:last = a:out[len(a:out) - 1]
let l:out = l:last ==? '' ? a:out[0:len(a:out) - 2] : a:out
" parsing errors
if a:status != 0
call prettier#job#runner#onError(a:err)
let s:prettier_job_running = 0
return
endif
" we have no prettier output so lets exit
if len(l:out) == 0 | return | endif
" nothing to update
if (prettier#utils#buffer#willUpdatedLinesChangeBuffer(l:out, a:info.start, a:info.end) == 0)
let s:prettier_job_running = 0
redraw!
return
endif
" This is required due to race condition when user quickly switch buffers while the async
" cli has not finished running, vim 8.0.1039 has introduced setbufline() which can be used
" to fix this issue in a cleaner way, however since we still need to support older vim versions
" we will apply a more generic solution
if (l:isInsideAnotherBuffer)
" Do no try to format buffers that have been closed
if (bufloaded(a:info.buf_nr))
try
silent exec 'sp '. escape(bufname(a:info.buf_nr), ' \')
call prettier#utils#buffer#replaceAndSave(l:out, a:info.start, a:info.end)
catch
call prettier#logging#error#log('PARSING_ERROR')
finally
" we should then hide this buffer again
if a:info.buf_nr == bufnr('%')
silent hide
endif
endtry
endif
else
call prettier#utils#buffer#replaceAndSave(l:out, a:info.start, a:info.end)
endif
let s:prettier_job_running = 0
endfunction

View file

@ -0,0 +1,69 @@
let s:prettier_job_running = 0
function! prettier#job#async#vim#run(cmd, startSelection, endSelection) abort
if s:prettier_job_running == 1
return
endif
let s:prettier_job_running = 1
let l:bufferName = bufname('%')
let l:job = job_start([&shell, &shellcmdflag, a:cmd], {
\ 'out_io': 'buffer',
\ 'err_cb': {channel, msg -> s:onError(msg)},
\ 'close_cb': {channel -> s:onClose(channel, a:startSelection, a:endSelection, l:bufferName)}})
let l:stdin = job_getchannel(l:job)
call ch_sendraw(l:stdin, join(getbufline(bufnr(l:bufferName), a:startSelection, a:endSelection), "\n"))
call ch_close_in(l:stdin)
endfunction
function! s:onError(msg) abort
call prettier#job#runner#onError(split(a:msg, '\n'))
let s:prettier_job_running = 0
endfunction
function! s:onClose(channel, startSelection, endSelection, bufferName) abort
let l:out = []
let l:currentBufferName = bufname('%')
let l:isInsideAnotherBuffer = a:bufferName != l:currentBufferName ? 1 : 0
let l:buff = ch_getbufnr(a:channel, 'out')
let l:out = getbufline(l:buff, 2, '$')
execute 'bd!' . l:buff
" we have no prettier output so lets exit
if len(l:out) == 0 | return | endif
" nothing to update
if (prettier#utils#buffer#willUpdatedLinesChangeBuffer(l:out, a:startSelection, a:endSelection) == 0)
let s:prettier_job_running = 0
redraw!
return
endif
" This is required due to race condition when user quickly switch buffers while the async
" cli has not finished running, vim 8.0.1039 has introduced setbufline() which can be used
" to fix this issue in a cleaner way, however since we still need to support older vim versions
" we will apply a more generic solution
if (l:isInsideAnotherBuffer)
" Do no try to format buffers that have been closed
if (bufloaded(str2nr(a:bufferName)))
try
silent exec 'sp '. escape(bufname(bufnr(a:bufferName)), ' \')
call prettier#utils#buffer#replaceAndSave(l:out, a:startSelection, a:endSelection)
catch
call prettier#logging#error#log('PARSING_ERROR', a:bufferName)
finally
" we should then hide this buffer again
if a:bufferName == bufname('%')
silent hide
endif
endtry
endif
else
call prettier#utils#buffer#replaceAndSave(l:out, a:startSelection, a:endSelection)
endif
let s:prettier_job_running = 0
endfunction

View file

@ -0,0 +1,63 @@
" TODO
" move the bellow vim checks to UTILS
let s:isLegacyVim = v:version < 800
let s:isNeoVim = has('nvim')
let s:isAsyncVim = !s:isLegacyVim && exists('*job_start')
function! prettier#job#runner#run(cmd, startSelection, endSelection, async) abort
if a:async && (s:isAsyncVim || s:isNeoVim)
call s:asyncFormat(a:cmd, a:startSelection, a:endSelection)
else
call s:format(a:cmd, a:startSelection, a:endSelection)
endif
endfunction
function! prettier#job#runner#onError(errors) abort
call prettier#logging#error#log('PARSING_ERROR')
if g:prettier#quickfix_enabled
call prettier#bridge#parser#onError(a:errors, g:prettier#quickfix_auto_focus)
endif
endfunction
function! s:asyncFormat(cmd, startSelection, endSelection) abort
if !s:isAsyncVim && !s:isNeoVim
call s:format(a:cmd, a:startSelection, a:endSelection)
endif
" required for Windows support on async operations
let l:cmd = a:cmd
if has('win32') || has('win64')
let l:cmd = 'cmd.exe /c ' . a:cmd
endif
if s:isAsyncVim
call prettier#job#async#vim#run(l:cmd, a:startSelection, a:endSelection)
else
call prettier#job#async#neovim#run(l:cmd, a:startSelection, a:endSelection)
endif
endfunction
function! s:format(cmd, startSelection, endSelection) abort
let l:bufferLinesList = getbufline(bufnr('%'), a:startSelection, a:endSelection)
" vim 7 does not have support for passing a list to system()
let l:bufferLines = s:isLegacyVim ? join(l:bufferLinesList, "\n") : l:bufferLinesList
" TODO
" since we are using two different types for system, maybe we should move it to utils shims
let l:out = split(system(a:cmd, l:bufferLines), '\n')
" check system exit code
if v:shell_error
call prettier#job#runner#onError(l:out)
return
endif
" TODO
" doing 0 checks seems weird can we do this bellow differently ?
if (prettier#utils#buffer#willUpdatedLinesChangeBuffer(l:out, a:startSelection, a:endSelection) == 0)
return
endif
call prettier#utils#buffer#replace(l:out, a:startSelection, a:endSelection)
endfunction

View file

@ -0,0 +1,12 @@
let s:PREFIX_MSG = 'Prettier: '
let s:ERRORS = {
\ 'EXECUTABLE_NOT_FOUND_ERROR': 'no prettier executable installation found',
\ 'PARSING_ERROR': 'failed to parse buffer',
\ }
let s:DEFAULT_ERROR = get(s:, 'PARSING_ERROR')
function! prettier#logging#error#log(...) abort
let l:error = a:0 > 0 ? a:1 : s:DEFAULT_ERROR
let l:msg = a:0 > 1 ? ': ' . a:2 : ''
echohl WarningMsg | echom s:PREFIX_MSG . get(s:ERRORS, l:error, s:DEFAULT_ERROR) . l:msg | echohl NONE
endfunction

View file

@ -0,0 +1,13 @@
" Return facebook style config overwrite presets
function! prettier#presets#fb#config() abort
return {
\ 'bracketSpacing': 'false',
\ 'jsxBracketSameLine': 'true',
\ 'printWidth': 80,
\ 'parser': 'flow',
\ 'singleQuote': 'true',
\ 'tabWidth': 2,
\ 'trailingComma': 'all',
\ 'useTabs': 'false',
\ }
endfunction

View file

@ -0,0 +1,101 @@
" By default we will default to our internal
" configuration settings for prettier
function! prettier#resolver#config#resolve(config, hasSelection, start, end) abort
" Allow params to be passed as json format
" convert bellow usage of globals to a get function o the params defaulting to global
" TODO: Use a list, filter() and join() to get a nicer list of args.
let l:cmd = s:Flag_use_tabs(a:config) . ' ' .
\ s:Flag_tab_width(a:config) . ' ' .
\ s:Flag_print_width(a:config) . ' ' .
\ s:Flag_parser(a:config) . ' ' .
\ s:Flag_range_delimiter(a:config, a:hasSelection, a:start, a:end) . ' ' .
\ ' --semi=' .
\ get(a:config, 'semi', g:prettier#config#semi) .
\ ' --single-quote=' .
\ get(a:config, 'singleQuote', g:prettier#config#single_quote) .
\ ' --bracket-spacing=' .
\ get(a:config, 'bracketSpacing', g:prettier#config#bracket_spacing) .
\ ' --jsx-bracket-same-line=' .
\ get(a:config, 'jsxBracketSameLine', g:prettier#config#jsx_bracket_same_line) .
\ ' --arrow-parens=' .
\ get(a:config, 'arrowParens', g:prettier#config#arrow_parens) .
\ ' --trailing-comma=' .
\ get(a:config, 'trailingComma', g:prettier#config#trailing_comma) .
\ ' --config-precedence=' .
\ get(a:config, 'configPrecedence', g:prettier#config#config_precedence) .
\ ' --prose-wrap=' .
\ get(a:config, 'proseWrap', g:prettier#config#prose_wrap) .
\ ' --html-whitespace-sensitivity ' .
\ get(a:config, 'htmlWhitespaceSensitivity', g:prettier#config#html_whitespace_sensitivity) .
\ ' --stdin-filepath="'.simplify(expand('%:p')).'"' .
\ ' --require-pragma=' .
\ get(a:config, 'requirePragma', g:prettier#config#require_pragma) .
\ ' --end-of-line=' .
\ get(a:config, 'endOfLine', g:prettier#config#end_of_line) .
\ ' --loglevel error '.
\ ' --stdin '
return l:cmd
endfunction
" Returns either '--range-start X --range-end Y' or an empty string.
function! s:Flag_range_delimiter(config, partialFormatEnabled, start, end) abort
if (!a:partialFormatEnabled)
return ''
endif
let l:range = prettier#utils#buffer#getCharRange(a:start, a:end)
return '--range-start=' . l:range[0] . ' --range-end=' . l:range[1]
endfunction
" Returns '--tab-width=NN'
function! s:Flag_tab_width(config) abort
let l:value = get(a:config, 'tabWidth', g:prettier#config#tab_width)
if (l:value ==# 'auto')
let l:value = prettier#utils#shim#shiftwidth()
endif
return '--tab-width=' . l:value
endfunction
" Returns either '--use-tabs' or an empty string.
function! s:Flag_use_tabs(config) abort
let l:value = get(a:config, 'useTabs', g:prettier#config#use_tabs)
if (l:value ==# 'auto')
let l:value = &expandtab ? 'false' : 'true'
endif
if ( l:value ==# 'true' )
return ' --use-tabs'
else
return ''
endif
endfunction
" Returns '--print-width=NN' or ''
function! s:Flag_print_width(config) abort
let l:value = get(a:config, 'printWidth', g:prettier#config#print_width)
if (l:value ==# 'auto')
let l:value = &textwidth
endif
if (l:value > 0)
return '--print-width=' . l:value
else
return ''
endif
endfunction
" Returns '--parser=PARSER' or ''
function! s:Flag_parser(config) abort
let l:value = get(a:config, 'parser', g:prettier#config#parser)
if (l:value !=# '')
return '--parser=' . l:value
else
return ''
endif
endfunction

View file

@ -0,0 +1,79 @@
let s:ROOT_DIR = fnamemodify(resolve(expand('<sfile>:p')), ':h')
" By default we will search for the following
" => user defined prettier cli path from vim configuration file
" => locally installed prettier inside node_modules on any parent folder
" => globally installed prettier
" => vim-prettier prettier installation
" => if all fails suggest install
function! prettier#resolver#executable#getPath() abort
let l:user_defined_exec_path = fnamemodify(g:prettier#exec_cmd_path, ':p')
if executable(l:user_defined_exec_path)
return l:user_defined_exec_path
endif
let l:localExec = s:ResolveExecutable(getcwd())
if executable(l:localExec)
return fnameescape(l:localExec)
endif
let l:globalExec = s:ResolveExecutable()
if executable(l:globalExec)
return fnameescape(l:globalExec)
endif
let l:pluginExec = s:ResolveExecutable(s:ROOT_DIR)
if executable(l:pluginExec)
return fnameescape(l:pluginExec)
endif
return -1
endfunction
function! s:GetExecPath(...) abort
let l:rootDir = a:0 > 0 ? a:1 : -1
let l:dir = l:rootDir != -1 ? l:rootDir . '/.bin/' : ''
let l:path = l:dir . get(b:, 'prettier_exec_cmd', 'prettier')
if executable(l:path)
return l:path
else
return l:dir . 'prettier'
endif
endfunction
" Searches for the existence of a directory accross
" ancestral parents
function! s:TraverseAncestorDirSearch(rootDir) abort
let l:root = a:rootDir
let l:dir = 'node_modules'
while 1
let l:searchDir = l:root . '/' . l:dir
if isdirectory(l:searchDir)
return l:searchDir
endif
let l:parent = fnamemodify(l:root, ':h')
if l:parent == l:root
return -1
endif
let l:root = l:parent
endwhile
endfunction
function! s:ResolveExecutable(...) abort
let l:rootDir = a:0 > 0 ? a:1 : 0
let l:exec = "."
if isdirectory(l:rootDir)
let l:dir = s:TraverseAncestorDirSearch(l:rootDir)
if l:dir != -1
let l:exec = s:GetExecPath(l:dir)
endif
else
let l:exec = s:GetExecPath()
endif
return l:exec
endfunction

View file

@ -0,0 +1,8 @@
" Build config using predefined preset
function! prettier#resolver#preset#resolve(fileTypeConfigOverwrites) abort
if ( g:prettier#preset#config ==# 'fb' )
return extend(prettier#presets#fb#config(), a:fileTypeConfigOverwrites)
endif
return a:fileTypeConfigOverwrites
endfunction

View file

@ -0,0 +1,70 @@
function! prettier#utils#buffer#replace(lines, startSelection, endSelection) abort
" store view
let l:winview = winsaveview()
let l:newBuffer = prettier#utils#buffer#createBufferFromUpdatedLines(a:lines, a:startSelection, a:endSelection)
" we should not replace contents if the newBuffer is empty
if empty(l:newBuffer)
return
endif
" https://vim.fandom.com/wiki/Restore_the_cursor_position_after_undoing_text_change_made_by_a_script
" create a fake change entry and merge with undo stack prior to do formating
execute "normal! i "
execute "normal! a\<BS>"
try | silent undojoin | catch | endtry
" delete all lines on the current buffer
silent! execute 'lockmarks %delete _'
" replace all lines from the current buffer with output from prettier
let l:idx = 0
for l:line in l:newBuffer
silent! lockmarks call append(l:idx, l:line)
let l:idx += 1
endfor
" delete trailing newline introduced by the above append procedure
silent! lockmarks execute '$delete _'
" Restore view
call winrestview(l:winview)
endfunction
" Replace and save the buffer
function! prettier#utils#buffer#replaceAndSave(lines, startSelection, endSelection) abort
call prettier#utils#buffer#replace(a:lines, a:startSelection, a:endSelection)
noautocmd write
endfunction
" Returns 1 if content has changed
function! prettier#utils#buffer#willUpdatedLinesChangeBuffer(lines, start, end) abort
return getbufline(bufnr('%'), 1, line('$')) == prettier#utils#buffer#createBufferFromUpdatedLines(a:lines, a:start, a:end) ? 0 : 1
endfunction
" Returns a new buffer with lines replacing start and end of the contents of the current buffer
function! prettier#utils#buffer#createBufferFromUpdatedLines(lines, start, end) abort
return getbufline(bufnr('%'), 1, a:start - 1) + a:lines + getbufline(bufnr('%'), a:end + 1, '$')
endfunction
" Adapted from https://github.com/farazdagi/vim-go-ide
function! s:getCharPosition(line, col) abort
if &encoding !=# 'utf-8'
" On utf-8 enconding we can't just use bytes so we need to make sure we can count the
" characters, we do that by adding the text into a temporary buffer and counting the chars
let l:buf = a:line == 1 ? '' : (join(getline(1, a:line - 1), "\n") . "\n")
let l:buf .= a:col == 1 ? '' : getline('.')[:a:col - 2]
return len(iconv(l:buf, &encoding, 'utf-8'))
endif
" On non utf-8 the line byte should match the character
return line2byte(a:line) + (a:col - 2)
endfun
" Returns [start, end] byte range when on visual mode
function! prettier#utils#buffer#getCharRange(startSelection, endSelection) abort
let l:range = []
call add(l:range, s:getCharPosition(a:startSelection, col("'<")))
call add(l:range, s:getCharPosition(a:endSelection, col("'>")))
return l:range
endfunction

View file

@ -0,0 +1,22 @@
" We use this flag so that we ensure only clearing quickfix if it was created by prettier itself
let s:prettier_quickfix_open = 0
function! prettier#utils#quickfix#close() abort
" close quickfix if it is opened
if s:prettier_quickfix_open
call setqflist([], 'r')
cclose
let s:prettier_quickfix_open = 0
endif
endfunction
function! prettier#utils#quickfix#open(errors, focus) abort
let s:prettier_quickfix_open = 1
let l:winnr = winnr()
call setqflist(a:errors, 'r')
botright copen
if !a:focus
" Return the cursor back to the main buffer.
exe l:winnr . 'wincmd w'
endif
endfunction

View file

@ -0,0 +1,8 @@
" Backwards compatable version of shiftwidth()
function! prettier#utils#shim#shiftwidth() abort
if exists('*shiftwidth')
return shiftwidth()
else
return &shiftwidth
endif
endfunction

View file

@ -0,0 +1,223 @@
*vim-prettier.txt* A prettier plugin for vim.
-------------------------------------------------------
vim-prettier: plugin wrapper for prettier
-------------------------------------------------------
Author: Mitermayer Reis <mitermayer.reis@gmail.com>
WebSite: https://prettier.io/
Repository: https://github.com/prettier/vim-prettier
License: MIT style license
Version: 1.0.0-beta
==============================================================================
CONTENTS *vim-prettier-contents*
Introduction |vim-prettier-introduction|
Install |vim-prettier-install|
Usage |vim-prettier-usage|
Configuration |vim-prettier-configuration|
Requirements |vim-prettier-requirements|
==============================================================================
INTRODUCTION *vim-prettier-introduction*
A vim plugin wrapper for prettier, pre-configured with
custom default prettier settings.
By default it will auto format javascript, typescript, less, scss, css,
json, and graphql files that have '@format' annotation in the header of the file.
When installed via vim-plug, a default prettier executable is installed inside
vim-prettier.
vim-prettier executable resolution:
1. Look for user defined prettier cli path from vim configuration file
2. Traverse parents and search for Prettier installation inside `node_modules`
3. Look for a global prettier installation
4. Use locally installed vim-prettier prettier executable
==============================================================================
INSTALL *vim-prettier-install*
Install with [vim-plug](https://github.com/junegunn/vim-plug), assumes
node and yarn|npm installed globally.
>
Plug 'prettier/vim-prettier', {
\ 'do': 'yarn install',
\ 'for': ['javascript', 'typescript', 'css',
\ 'less', 'scss', 'json', 'graphql', 'markdown', 'vue', 'svelte', 'yaml',
'html'] }
<
or simply enable for all formats by:
>
Plug 'prettier/vim-prettier', { 'do': 'yarn install' }
<
If using other vim plugin managers or doing manual setup make sure to have
`prettier` installed globally or go to your vim-prettier directory and
either do `npm install` or `yarn install`
==============================================================================
USAGE *vim-prettier-usage*
Prettier by default will run on auto save but can also
be manually triggered by:
>
<Leader>p
<
or
>
:Prettier
<
If your are on vim 8+ you can also trigger async formatting by:
>
:PrettierAsync
<
You can check what is the `vim-prettier` plugin version by:
>
:PrettierVersion
<
You can send commands to the resolved `prettier` cli by:
>
:PrettierCli <q-args>
<
You can check what is the resolved `prettier` cli path by:
>
:PrettierCliPath
<
You can check what is the resolved `prettier` cli version by:
>
:PrettierCliVersion
You can send to prettier your entire buffer but ensure that it
formats only your selection.
**note:** differs from `:PrettierFragment` by sending the entire buffer
to prettier, allowing identation level to be preserved, but it requires
the whole file to be valid.
>
:PrettierPartial
You can send to prettier your current selection as a fragment of same type as
the file being edited.
**note:** differs from `:PrettierPartial` by sending only the current selection
to prettier, this allows for faster formatting but wont preserve indentation.
>
:PrettierFragment
==============================================================================
CONFIGURATION *vim-prettier-configuration*
Enable auto formatting of files that have "@format" or "@prettier" tag
>
let g:prettier#autoformat = 1
Enable auto formatting of files based on whether a Prettier configuration file has been
found in the project directory or any parent directories.
>
let g:prettier#autoformat_config_present = 1
Configuration file names to search for when attempting to find an appropriate
Prettier configuration file for the current project.
>
let g:prettier#autoformat_config_files = [...]
<
Set the prettier CLI executable path
>
let g:prettier#exec_cmd_path = "~/path/to/cli/prettier"
<
The command `:Prettier` by default is synchronous but can also be forced async
>
let g:prettier#exec_cmd_async = 1
<
By default parsing errors will open the quickfix but can also be disabled
>
let g:prettier#quickfix_enabled = 1
<
By default we auto focus on the quickfix when there are errors but can also be disabled
>
let g:prettier#quickfix_auto_focus = 0
<
To enable vim-prettier to auto run in files without requiring the "@format" or "@prettier" doc tag.
First ensure that `g:prettier#autoformat` is not enabled on your `vimrc` (it should be disabled by default), then update to your own custom behaviour
Running before saving sync:
>
autocmd BufWritePre *.js,*.jsx,*.mjs,*.ts,*.tsx,*.css,*.less,*.scss,*.json,*.graphql,*.md,*.vue,*.svelte,*.yaml,*.html Prettier
<
Running before saving async (vim 8+):
>
autocmd BufWritePre *.js,*.jsx,*.mjs,*.ts,*.tsx,*.css,*.less,*.scss,*.json,*.graphql,*.md,*.vue,*.svelte,*.yaml,*.html PrettierAsync
<
Running before saving, changing text or leaving insert mode:
>
" when running at every change you may want to disable quickfix
let g:prettier#quickfix_enabled = 0
autocmd BufWritePre,TextChanged,InsertLeave *.js,*.jsx,*.mjs,*.ts,*.tsx,*.css,*.less,*.scss,*.json,*.graphql,*.md,*.vue,*.svelte,*.yaml,*.html PrettierAsync
<
Buffer-level custom commands
To use an alternative command, like `prettier-stylelint`, set this at the
buffer level with `b:prettier_exec_cmd`, e.g.:
>
au FileType css,scss let b:prettier_exec_cmd = "prettier-stylelint"
<
vim-prettier will look for the executable in the same places it looks for
`prettier`, and will fall back to `prettier` if it can't find
`b:prettier_exec_cmd`
Overwrite default prettier configuration
**Note:** vim-prettier default settings differ from prettier intentionally.
However they can be configured by:
>
" Max line length that prettier will wrap on: a number or 'auto' (use
" textwidth).
" default: 'auto'
let g:prettier#config#print_width = 'auto'
" number of spaces per indentation level: a number or 'auto' (use
" softtabstop)
" default: 'auto'
let g:prettier#config#tab_width = 'auto'
" use tabs instead of spaces: true, false, or auto (use the expandtab setting).
" default: 'auto'
let g:prettier#config#use_tabs = 'auto'
" flow|babylon|typescript|css|less|scss|json|graphql|markdown or empty string
" (let prettier choose).
" default: ''
let g:prettier#config#parser = ''
" cli-override|file-override|prefer-file
" default: 'file-override'
let g:prettier#config#config_precedence = 'file-override'
" always|never|preserve
" default: 'preserve'
let g:prettier#config#prose_wrap = 'preserve'
" css|strict|ignore
let g:prettier#config#html_whitespace_sensitivity = 'css'
" false|true
" default: 'false'
" let g:prettier#config#require_pragma = 'false'
" Define the flavor of line endings
" lf|crlf|cr|all
" defaut: 'lf'
let g:prettier#config#end_of_line = get(g:, 'prettier#config#end_of_line', 'lf')
==============================================================================
REQUIREMENT(S) *vim-prettier-requirements*
If prettier is not installed locally, globally or inside vim-prettier project
no code formatting will happen
==============================================================================
vim:tw=78:ts=4:ft=help:norl:noet:fen:noet:

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.css setfiletype css
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.graphql,*.gql setfiletype graphql
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.html setfiletype html
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.js,*jsx setfiletype javascript
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.json setfiletype json
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.less setfiletype less
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.lua setfiletype lua
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.markdown,*.md,*.mdown,*.mkd,*.mkdn setfiletype markdown
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.php setfiletype php
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.rb setfiletype ruby
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.scss setfiletype scss
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.svelte setfiletype svelte
augroup end

View file

@ -0,0 +1,4 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.ts setfiletype typescript
autocmd BufNewFile,BufReadPost *.tsx setfiletype typescriptreact
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.vue setfiletype vue
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.xml setfiletype xml
augroup end

View file

@ -0,0 +1,3 @@
augroup PrettierFileDetect
autocmd BufNewFile,BufReadPost *.yaml,*.yml setfiletype yaml
augroup end

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'css',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'graphql',
\ }

View file

@ -0,0 +1,7 @@
" markdown/php files run this as well
" https://stackoverflow.com/questions/22839269/why-does-vim-default-markdown-ftplugin-source-html-ftplugins-is-there-any-ways
if expand('%:e') ==# 'html'
let b:prettier_ft_default_args = {
\ 'parser': 'html',
\ }
endif

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'json',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'less',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'lua',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'markdown',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'php',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'ruby',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'scss',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'svelte',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'typescript',
\ }

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'vue',
\ }

View file

@ -0,0 +1,7 @@
" markdown/php files run this as well
" https://stackoverflow.com/questions/22839269/why-does-vim-default-markdown-ftplugin-source-html-ftplugins-is-there-any-ways
if expand('%:e') ==# 'xml'
let b:prettier_ft_default_args = {
\ 'parser': 'xml',
\ }
endif

View file

@ -0,0 +1,3 @@
let b:prettier_ft_default_args = {
\ 'parser': 'yaml',
\ }

Binary file not shown.

After

Width:  |  Height:  |  Size: 559 KiB

View file

@ -0,0 +1,28 @@
{
"name": "vim-prettier",
"author": "Mitermayer Reis <mitermayer.reis@gmail.com>",
"version": "1.0.0-beta",
"description": "Vim plugin for prettier",
"license": "MIT",
"repository": {
"type": "git",
"url": "git://github.com/prettier/vim-prettier.git"
},
"scripts": {
"test": "vim --version && LOG_LEVEL=error jest",
"lint": "vint --version && vint ."
},
"dependencies": {
"@prettier/plugin-lua": "0.0.1",
"@prettier/plugin-php": "^0.16.3",
"@prettier/plugin-ruby": "^0.8.0",
"@prettier/plugin-xml": "^0.7.2",
"prettier-plugin-svelte": "^2.3.1",
"prettier": "^2.3.1"
},
"devDependencies": {
"colors": "^1.3.2",
"jest": "^23.6.0",
"vim-driver": "^1.0.0"
}
}

View file

@ -0,0 +1,178 @@
" vim-prettier: A vim plugin wrapper for prettier, pre-configured with custom default prettier settings.
"
" Script Info {{{
"==========================================================================================================
" Name Of File: prettier.vim
" Description: A vim plugin wrapper for prettier, pre-configured with custom default prettier settings.
" Maintainer: Mitermayer Reis <mitermayer.reis at gmail.com>
" Version: 1.0.0-beta
" Usage: Use :help vim-prettier-usage, or visit https://github.com/prettier/vim-prettier
"
"==========================================================================================================
" }}}
if exists('g:loaded_prettier')
finish
endif
let g:loaded_prettier = 1
" => Plugin config
" autoformating disabled by default upon saving
let g:prettier#autoformat = get(g:, 'prettier#autoformat', 0)
" autoformating requires pragma by default
let g:prettier#autoformat_require_pragma = get(g:, 'prettier#autoformat_require_pragma', 1)
" whether to turn autoformatting on if a prettier config file is found
let g:prettier#autoformat_config_present = get(g:, 'prettier#autoformat_config_present', 0)
" prettier config files to search current directory and parent directories for
let g:prettier#autoformat_config_files = get(g:, 'prettier#autoformat_config_files', [
\'.prettierrc',
\'.prettierrc.yml',
\'.prettierrc.yaml',
\'.prettierrc.js',
\'.prettierrc.config.js',
\'.prettierrc.json',
\'.prettierrc.toml'])
" path to prettier cli
let g:prettier#exec_cmd_path = get(g:, 'prettier#exec_cmd_path', 0)
" calling :Prettier by default runs synchronous
let g:prettier#exec_cmd_async = get(g:, 'prettier#exec_cmd_async', 0)
" when having formatting errors will open the quickfix by default
let g:prettier#quickfix_enabled = get(g:, 'prettier#quickfix_enabled', 1)
" Don't leave the quicklist focused on error.
let g:prettier#quickfix_auto_focus = get(g:, 'prettier#quickfix_auto_focus', 1)
" Send to prettier entire buffer and use --range-start and --range-end as delimter
let g:prettier#partial_format = get(g:, 'prettier#partial_format', 0)
" default|fb
" Use prettier defaults
let g:prettier#preset#config = get(g:,'prettier#preset#config', 'default')
" => Prettier CLI config
" Max line length that prettier will wrap on: a number or 'auto' (use
" textwidth).
" default: 'auto'
" See more: https://prettier.io/docs/en/options.html#print-width
let g:prettier#config#print_width = get(g:, 'prettier#config#print_width', 'auto')
" number of spaces per indentation level: a number or 'auto' (use
" softtabstop)
" default: 'auto'
" See more: https://prettier.io/docs/en/options.html#tab-width
let g:prettier#config#tab_width = get(g:,'prettier#config#tab_width', 'auto')
" use tabs instead of spaces: true, false, or auto (use the expandtab setting).
" default: 'auto'
" See more: https://prettier.io/docs/en/options.html#tabs
let g:prettier#config#use_tabs = get(g:,'prettier#config#use_tabs', 'auto')
" flow|babylon|typescript|css|less|scss|json|graphql|markdown or empty string
" (let prettier choose).
" default: ''
" See more: https://prettier.io/docs/en/options.html#parser
let g:prettier#config#parser = get(g:,'prettier#config#parser', '')
" cli-override|file-override|prefer-file
" default: 'file-override'
" See more: https://prettier.io/docs/en/cli.html#--config-precedence
let g:prettier#config#config_precedence = get(g:, 'prettier#config#config_precedence', 'file-override')
" always|never|preserve
" default: 'preserve'
" See more: https://prettier.io/docs/en/options.html#prose-wrap
let g:prettier#config#prose_wrap = get(g:, 'prettier#config#prose_wrap', 'preserve')
" css|strict|ignore
" default: 'css'
" See more: https://prettier.io/docs/en/options.html#html-whitespace-sensitivity
let g:prettier#config#html_whitespace_sensitivity = get(g:, 'prettier#config#html_whitespace_sensitivity', 'css')
" print semicolons
" default: 'true'
" See more: https://prettier.io/docs/en/options.html#semicolons
let g:prettier#config#semi = get(g:,'prettier#config#semi', 'true')
" Use single quotes instead of double quotes.
" default: 'false'
" See more: https://prettier.io/docs/en/options.html#quotes
let g:prettier#config#single_quote = get(g:,'prettier#config#single_quote', 'false')
" print spaces between brackets
" default: 'true'
" See more: https://prettier.io/docs/en/options.html#bracket-spacing
let g:prettier#config#bracket_spacing = get(g:,'prettier#config#bracket_spacing', 'true')
" put > on the last line instead of new line
" default: 'false'
" See more: https://prettier.io/docs/en/options.html#jsx-brackets
let g:prettier#config#jsx_bracket_same_line = get(g:,'prettier#config#jsx_bracket_same_line', 'false')
" avoid wrapping a single arrow function param in parens
" avoid|always
" default: 'always'
" See more: https://prettier.io/docs/en/options.html#arrow-function-parentheses
let g:prettier#config#arrow_parens = get(g:,'prettier#config#arrow_parens', 'always')
" Define the flavor of line endings
" lf|crlf|cr|all
" defaut: 'lf'
let g:prettier#config#end_of_line = get(g:, 'prettier#config#end_of_line', 'lf')
" Print trailing commas wherever possible when multi-line.
" none|es5|all
" default: 'es5'
" See more: https://prettier.io/docs/en/options.html#trailing-commas
let g:prettier#config#trailing_comma = get(g:,'prettier#config#trailing_comma', 'es5')
" restrict itself to only format files that contain a special comment @prettier or @format
" See more: https://prettier.io/docs/en/options.html#require-pragma
let g:prettier#config#require_pragma= get(g:, 'prettier#config#require_pragma', 'false')
" synchronous by default
command! -nargs=? -range=% Prettier call prettier#Prettier(g:prettier#exec_cmd_async, <line1>, <line2>, g:prettier#partial_format)
" prettier async
command! -nargs=? -range=% PrettierAsync call prettier#Prettier(1, <line1>, <line2>, g:prettier#partial_format)
" prints vim-prettier version
command! -nargs=? -range=% PrettierVersion echom '1.0.0-beta'
" call prettier cli
command! -nargs=? -range=% PrettierCli call prettier#PrettierCli(<q-args>)
" call prettier cli to get its version
command! -nargs=? -range=% PrettierCliVersion call prettier#PrettierCli('--version')
" prints prettier resolved cli path
command! -nargs=? -range=% PrettierCliPath call prettier#PrettierCliPath()
" sends selected text to prettier cli for formatting
command! -nargs=? -range=% PrettierFragment call prettier#Prettier(g:prettier#exec_cmd_async, <line1>, <line2>, 0)
" sends entire buffer to prettier cli but format just selection
command! -nargs=? -range=% PrettierPartial call prettier#Prettier(g:prettier#exec_cmd_async, <line1>, <line2>, 1)
" map command
if !hasmapto('<Plug>(Prettier)') && maparg('<Leader>p', 'n') ==# ''
nmap <unique> <Leader>p <Plug>(Prettier)
endif
nnoremap <silent> <Plug>(Prettier) :Prettier<CR>
nnoremap <silent> <Plug>(PrettierAsync) :PrettierAsync<CR>
nnoremap <silent> <Plug>(PrettierFragment) :PrettierFragment<CR>
nnoremap <silent> <Plug>(PrettierPartial) :PrettierPartial<CR>
nnoremap <silent> <Plug>(PrettierVersion) :PrettierVersion<CR>
nnoremap <silent> <Plug>(PrettierCli) :PrettierCli<CR>
nnoremap <silent> <Plug>(PrettierCliVersion) :PrettierCliVersion<CR>
nnoremap <silent> <Plug>(PrettierCliPath) :PrettierCliPath<CR>
augroup Prettier
autocmd!
autocmd BufWritePre *.js,*.jsx,*.mjs,*.ts,*.tsx,*.css,*.less,*.scss,*.json,*.graphql,*.gql,*.markdown,*.md,*.mdown,*.mkd,*.mkdn,*.mdx,*.vue,*.svelte,*.yml,*.yaml,*.html,*.php,*.rb,*.ruby,*.xml noautocmd call prettier#Autoformat()
augroup end

View file

@ -0,0 +1,329 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Prettier formats foo.css file with :Prettier command 1`] = `
".redClass {
background: \\"red\\";
}
#redId {
background: \\"red\\";
}"
`;
exports[`Prettier formats foo.css file with :PrettierAsync command 1`] = `
".redClass {
background: \\"red\\";
}
#redId {
background: \\"red\\";
}"
`;
exports[`Prettier formats foo.graphql file with :Prettier command 1`] = `
"{
baz {
blah
...name
}
bean {
foo
blah
bleh
}
bar {
...name
}
}"
`;
exports[`Prettier formats foo.graphql file with :PrettierAsync command 1`] = `
"{
baz {
blah
...name
}
bean {
foo
blah
bleh
}
bar {
...name
}
}"
`;
exports[`Prettier formats foo.html file with :Prettier command 1`] = `
"<html>
<head>
<title>foo</title>
</head>
<body>
<h1>foo</h1>
</body>
</html>"
`;
exports[`Prettier formats foo.html file with :PrettierAsync command 1`] = `
"<html>
<head>
<title>foo</title>
</head>
<body>
<h1>foo</h1>
</body>
</html>"
`;
exports[`Prettier formats foo.js file with :Prettier command 1`] = `
"const a = () => {
return 2;
};"
`;
exports[`Prettier formats foo.js file with :PrettierAsync command 1`] = `
"const a = () => {
return 2;
};"
`;
exports[`Prettier formats foo.json file with :Prettier command 1`] = `
"{
\\"name\\": \\"foo\\",
\\"bar\\": \\"baz\\"
}"
`;
exports[`Prettier formats foo.json file with :PrettierAsync command 1`] = `
"{
\\"name\\": \\"foo\\",
\\"bar\\": \\"baz\\"
}"
`;
exports[`Prettier formats foo.less file with :Prettier command 1`] = `
".redClass {
background: \\"red\\";
}
#redId {
background: \\"red\\";
}"
`;
exports[`Prettier formats foo.less file with :PrettierAsync command 1`] = `
".redClass {
background: \\"red\\";
}
#redId {
background: \\"red\\";
}"
`;
exports[`Prettier formats foo.lua file with :Prettier command 1`] = `
"function deepcopy(orig)
local orig_type = type(orig)
local copy
return copy
end"
`;
exports[`Prettier formats foo.lua file with :PrettierAsync command 1`] = `
"function deepcopy(orig)
local orig_type = type(orig)
local copy
return copy
end"
`;
exports[`Prettier formats foo.md file with :Prettier command 1`] = `
"## foo
Lorem ipsum dolor amet
### bar
- a
- b
- c"
`;
exports[`Prettier formats foo.md file with :PrettierAsync command 1`] = `
"## foo
Lorem ipsum dolor amet
### bar
- a
- b
- c"
`;
exports[`Prettier formats foo.php file with :Prettier command 1`] = `
"<?php
$a = 'a';
$b = $a . $a . ' asda';"
`;
exports[`Prettier formats foo.php file with :PrettierAsync command 1`] = `
"<?php
$a = 'a';
$b = $a . $a . ' asda';"
`;
exports[`Prettier formats foo.rb file with :Prettier command 1`] = `
"[1, 2, 3].each do |i|
p i
end"
`;
exports[`Prettier formats foo.rb file with :PrettierAsync command 1`] = `
"[1, 2, 3].each do |i|
p i
end"
`;
exports[`Prettier formats foo.scss file with :Prettier command 1`] = `
".redClass {
background: \\"red\\";
}
#redId {
background: \\"red\\";
}"
`;
exports[`Prettier formats foo.scss file with :PrettierAsync command 1`] = `
".redClass {
background: \\"red\\";
}
#redId {
background: \\"red\\";
}"
`;
exports[`Prettier formats foo.ts file with :Prettier command 1`] = `
"const a: () => number = () => {
return 2;
};"
`;
exports[`Prettier formats foo.ts file with :PrettierAsync command 1`] = `
"const a: () => number = () => {
return 2;
};"
`;
exports[`Prettier formats foo.vue file with :Prettier command 1`] = `
"<template>
<div class=\\"example\\">{{ msg }}</div>
</template>
<script>
export default {
data() {
return { msg: \\"Hello world!\\" };
}
};
</script>
<style>
.example {
color: red;
}
</style>
<custom1>
This could be e.g. documentation for the component.
</custom1>"
`;
exports[`Prettier formats foo.vue file with :PrettierAsync command 1`] = `
"<template>
<div class=\\"example\\">{{ msg }}</div>
</template>
<script>
export default {
data() {
return { msg: \\"Hello world!\\" };
}
};
</script>
<style>
.example {
color: red;
}
</style>
<custom1>
This could be e.g. documentation for the component.
</custom1>"
`;
exports[`Prettier formats foo.xml file with :Prettier command 1`] = `
"<?xml version=\\"1.0\\" encoding=\\"UTF-8\\" ?>
<!DOCTYPE module PUBLIC \\"-//Puppy Crawl//DTD Check Configuration 1.3//EN\\"
\\"https://www.puppycrawl.com/dtds/configuration_1_3.dtd\\">
<?xml-model href=\\"project.rnc\\" type=\\"application/relax-ng-compact-syntax\\"?>
<!-- foo -->
<svg
xmlns=\\"http://www.w3.org/2000/svg\\"
xmlns:xlink=\\"http://www.w3.org/1999/xlink\\"
width=\\"200\\"
height=\\"100\\"
viewBox=\\"0 0 200 100\\"
>
<title>foo</title>
<desc _attr=\\"attr\\">
bar
</desc>
<style />
</svg>
<!-- bar -->"
`;
exports[`Prettier formats foo.xml file with :PrettierAsync command 1`] = `
"<?xml version=\\"1.0\\" encoding=\\"UTF-8\\" ?>
<!DOCTYPE module PUBLIC \\"-//Puppy Crawl//DTD Check Configuration 1.3//EN\\"
\\"https://www.puppycrawl.com/dtds/configuration_1_3.dtd\\">
<?xml-model href=\\"project.rnc\\" type=\\"application/relax-ng-compact-syntax\\"?>
<!-- foo -->
<svg
xmlns=\\"http://www.w3.org/2000/svg\\"
xmlns:xlink=\\"http://www.w3.org/1999/xlink\\"
width=\\"200\\"
height=\\"100\\"
viewBox=\\"0 0 200 100\\"
>
<title>foo</title>
<desc _attr=\\"attr\\">
bar
</desc>
<style />
</svg>
<!-- bar -->"
`;
exports[`Prettier formats foo.yaml file with :Prettier command 1`] = `
"foo:
bar:
baz:
bleh: ./foo
foobar: foobar
args:
buildno: 1"
`;
exports[`Prettier formats foo.yaml file with :PrettierAsync command 1`] = `
"foo:
bar:
baz:
bleh: ./foo
foobar: foobar
args:
buildno: 1"
`;

View file

@ -0,0 +1,3 @@
.redClass { background: 'red';}
#redId {
background: 'red';}

View file

@ -0,0 +1,8 @@
{
baz {
blah, ...name }
bean{foo, blah,bleh}
bar {
...name
}
}

View file

@ -0,0 +1,3 @@
<html>
<head><title>foo</title></head>
<body><h1>foo</h1></body></html>

View file

@ -0,0 +1 @@
const a = () => { return 2; };

View file

@ -0,0 +1,3 @@
{
"name": "foo", "bar": "baz"
}

View file

@ -0,0 +1,3 @@
.redClass { background: 'red';}
#redId {
background: 'red';}

View file

@ -0,0 +1,6 @@
function deepcopy(orig)
local orig_type = type(orig)
local copy
return copy
end

View file

@ -0,0 +1,11 @@
## foo
Lorem ipsum dolor amet
### bar
- a
- b
- c

View file

@ -0,0 +1,4 @@
<?php
$a='a';
$b = $a. $a .' asda';

View file

@ -0,0 +1,3 @@
for i in [1, 2, 3] do
p i
end

View file

@ -0,0 +1,3 @@
.redClass { background: 'red';}
#redId {
background: 'red';}

View file

@ -0,0 +1 @@
const a: () => number = () => { return 2; };

View file

@ -0,0 +1,14 @@
<template> <div class="example">{{ msg }}</div> </template>
<script>
export default {
data () { return { msg: 'Hello world!' } } }
</script>
<style>
.example { color: red; }
</style>
<custom1>
This could be e.g. documentation for the component.
</custom1>

View file

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE module PUBLIC "-//Puppy Crawl//DTD Check Configuration 1.3//EN"
"https://www.puppycrawl.com/dtds/configuration_1_3.dtd">
<?xml-model href="project.rnc" type="application/relax-ng-compact-syntax"?>
<!-- foo -->
<svg
xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink"
width="200"
height="100"
viewBox="0 0 200 100"
>
<title>foo</title>
<desc _attr="attr">
bar
</desc>
<style></style>
</svg>
<!-- bar -->

After

Width:  |  Height:  |  Size: 534 B

View file

@ -0,0 +1,11 @@
foo:
bar:
baz:
bleh: ./foo
foobar: foobar
args:
buildno: 1

View file

@ -0,0 +1,126 @@
const fs = require('fs');
const path = require('path');
const HeadlessRemoteClient = require('vim-driver/dist/HeadlessRemoteClient');
const Server = require('vim-driver/dist/Server');
const HOST = '127.0.0.1';
const PORT = 1337;
const FIXTURES_DIR = `${__dirname}/fixtures`;
let server;
let remote;
jest.setTimeout(15000);
const getBufferContents = async remote =>
(await remote.call('getline', [1, '$'])).join('\n');
const sleep = ms => new Promise(resolve => setTimeout(resolve, ms));
const waitUntil = (condition, timeout = 2000) => {
return new Promise(resolve => {
let isTimedOut = false;
let timeoutId = null;
const check = () => {
const promise = condition();
promise.then(result => {
if (!isTimedOut && result === true) {
clearTimeout(timeoutId);
resolve();
} else if (!isTimedOut) {
check();
}
});
};
timeoutId = setTimeout(() => {
isTimedOut = true;
resolve();
}, timeout);
});
};
const assertFormatting = (file) => {
const filename = path.basename(file);
test(`Prettier formats ${filename} file with :Prettier command`, async () => {
await remote.edit(`${FIXTURES_DIR}/${file}`);
const lines = await getBufferContents(remote);
// run sync formatting
await remote.execute('Prettier');
const updatedLines = await getBufferContents(remote);
// we now check that we have indeed formatted the code
expect(updatedLines).not.toBe(lines);
// check snapshot
expect(updatedLines).toMatchSnapshot();
});
test(`Prettier formats ${filename} file with :PrettierAsync command`, async () => {
await remote.edit(`${FIXTURES_DIR}/${file}`);
const lines = await getBufferContents(remote);
// run async formatting
await remote.execute('PrettierAsync');
const unmodifiedLines = await getBufferContents(remote);
// async should not happen immediatly so content should still remain the same
expect(unmodifiedLines).toBe(lines);
// we now will wait until prettier has finally updated the content async
await waitUntil(async () => (await getBufferContents(remote)) !== lines);
const updatedLines = await getBufferContents(remote);
// we now check that we have indeed formatted the code
expect(lines).not.toBe(updatedLines);
// check snapshot
expect(updatedLines).toMatchSnapshot();
});
};
beforeAll(async () => {
server = new Server();
await server.listen(HOST, PORT);
});
afterAll(async () => {
await server.close();
});
// should ensure that we cache original fixture contents and
// restore it on the afterEach
beforeEach(async () => {
remote = new HeadlessRemoteClient({host: HOST, port: PORT});
await remote.connect(server);
});
afterEach(async () => {
if (remote.isConnected()) {
try {
const filename = await remote.call('expand', ['%:p']);
if (filename) {
// restore the file
await remote.execute('earlier 1d | noautocmd | write');
}
} catch (e) {
} finally {
await remote.close();
}
}
});
//test('PrettierVersion returns pluggin version', async () => {
// const result = await remote.execute('PrettierVersion');
// expect(result).toMatchSnapshot();
//});
// run formatting tests in all fixtures
fs.readdirSync(FIXTURES_DIR).forEach(file => assertFormatting(file));

View file

@ -0,0 +1,35 @@
" vint: -ProhibitSetNoCompatible
source /rtp.vim
" Load builtin plugins
" We need this because run_vim.sh sets -i NONE
if has('win32')
set runtimepath=$VIM/vimfiles,$VIMRUNTIME,$VIM/vimfiles/after,C:\vader,C:\testplugin
else
set runtimepath=/home/vim,$VIM/vimfiles,$VIMRUNTIME,$VIM/vimfiles/after,/testplugin,/vader
endif
" The following is just an example
filetype plugin indent on
syntax on
if !has('win32')
set shell=/bin/sh
set shellcmdflag=-c
endif
set nocompatible
set tabstop=4
set softtabstop=4
set shiftwidth=4
set expandtab
set backspace=2
set nofoldenable
set foldmethod=syntax
set foldlevelstart=10
set foldnestmax=10
set ttimeoutlen=0
" The encoding must be explicitly set for tests for Windows.
execute 'set encoding=utf-8'

File diff suppressed because it is too large Load diff