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:
parent
f7b1840547
commit
a8e788a215
77 changed files with 6370 additions and 0 deletions
12
dotfiles/.vim/plugged/vim-prettier/.github/ISSUE_TEMPLATE.md
vendored
Normal file
12
dotfiles/.vim/plugged/vim-prettier/.github/ISSUE_TEMPLATE.md
vendored
Normal 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 ?**
|
||||
|
19
dotfiles/.vim/plugged/vim-prettier/.github/PULL_REQUEST_TEMPLATE.md
vendored
Normal file
19
dotfiles/.vim/plugged/vim-prettier/.github/PULL_REQUEST_TEMPLATE.md
vendored
Normal 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**
|
||||
|
||||
[...]
|
5
dotfiles/.vim/plugged/vim-prettier/.gitignore
vendored
Normal file
5
dotfiles/.vim/plugged/vim-prettier/.gitignore
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
TODO
|
||||
doc/tags
|
||||
node_modules
|
||||
.yarn_lock
|
||||
yarn.lock
|
12
dotfiles/.vim/plugged/vim-prettier/.gitrepo
Normal file
12
dotfiles/.vim/plugged/vim-prettier/.gitrepo
Normal 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
|
537
dotfiles/.vim/plugged/vim-prettier/CHANGELOG.md
Normal file
537
dotfiles/.vim/plugged/vim-prettier/CHANGELOG.md
Normal 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)*
|
66
dotfiles/.vim/plugged/vim-prettier/Dockerfile
Normal file
66
dotfiles/.vim/plugged/vim-prettier/Dockerfile
Normal 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
|
7
dotfiles/.vim/plugged/vim-prettier/LICENSE
Normal file
7
dotfiles/.vim/plugged/vim-prettier/LICENSE
Normal 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.
|
63
dotfiles/.vim/plugged/vim-prettier/Makefile
Normal file
63
dotfiles/.vim/plugged/vim-prettier/Makefile
Normal 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
|
287
dotfiles/.vim/plugged/vim-prettier/README.md
Normal file
287
dotfiles/.vim/plugged/vim-prettier/README.md
Normal 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
|
98
dotfiles/.vim/plugged/vim-prettier/autoload/prettier.vim
Normal file
98
dotfiles/.vim/plugged/vim-prettier/autoload/prettier.vim
Normal 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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
223
dotfiles/.vim/plugged/vim-prettier/doc/prettier.txt
Normal file
223
dotfiles/.vim/plugged/vim-prettier/doc/prettier.txt
Normal 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:
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/css.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/css.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.css setfiletype css
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/graphql.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/graphql.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.graphql,*.gql setfiletype graphql
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/html.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/html.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.html setfiletype html
|
||||
augroup end
|
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.js,*jsx setfiletype javascript
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/json.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/json.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.json setfiletype json
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/less.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/less.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.less setfiletype less
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/lua.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/lua.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.lua setfiletype lua
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/markdown.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/markdown.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.markdown,*.md,*.mdown,*.mkd,*.mkdn setfiletype markdown
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/php.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/php.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.php setfiletype php
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/ruby.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/ruby.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.rb setfiletype ruby
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/scss.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/scss.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.scss setfiletype scss
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/svelte.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/svelte.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.svelte setfiletype svelte
|
||||
augroup end
|
|
@ -0,0 +1,4 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.ts setfiletype typescript
|
||||
autocmd BufNewFile,BufReadPost *.tsx setfiletype typescriptreact
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/vue.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/vue.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.vue setfiletype vue
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/xml.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/xml.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.xml setfiletype xml
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/yaml.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftdetect/yaml.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
augroup PrettierFileDetect
|
||||
autocmd BufNewFile,BufReadPost *.yaml,*.yml setfiletype yaml
|
||||
augroup end
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/css.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/css.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'css',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/graphql.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/graphql.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'graphql',
|
||||
\ }
|
7
dotfiles/.vim/plugged/vim-prettier/ftplugin/html.vim
Normal file
7
dotfiles/.vim/plugged/vim-prettier/ftplugin/html.vim
Normal 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
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/json.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/json.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'json',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/less.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/less.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'less',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/lua.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/lua.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'lua',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/markdown.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/markdown.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'markdown',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/php.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/php.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'php',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/ruby.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/ruby.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'ruby',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/scss.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/scss.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'scss',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/svelte.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/svelte.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'svelte',
|
||||
\ }
|
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'typescript',
|
||||
\ }
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/vue.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/vue.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'vue',
|
||||
\ }
|
7
dotfiles/.vim/plugged/vim-prettier/ftplugin/xml.vim
Normal file
7
dotfiles/.vim/plugged/vim-prettier/ftplugin/xml.vim
Normal 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
|
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/yaml.vim
Normal file
3
dotfiles/.vim/plugged/vim-prettier/ftplugin/yaml.vim
Normal file
|
@ -0,0 +1,3 @@
|
|||
let b:prettier_ft_default_args = {
|
||||
\ 'parser': 'yaml',
|
||||
\ }
|
BIN
dotfiles/.vim/plugged/vim-prettier/media/vim-prettier.gif
Normal file
BIN
dotfiles/.vim/plugged/vim-prettier/media/vim-prettier.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 559 KiB |
28
dotfiles/.vim/plugged/vim-prettier/package.json
Normal file
28
dotfiles/.vim/plugged/vim-prettier/package.json
Normal 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"
|
||||
}
|
||||
}
|
178
dotfiles/.vim/plugged/vim-prettier/plugin/prettier.vim
Normal file
178
dotfiles/.vim/plugged/vim-prettier/plugin/prettier.vim
Normal 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
|
|
@ -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"
|
||||
`;
|
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.css
vendored
Normal file
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.css
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
.redClass { background: 'red';}
|
||||
#redId {
|
||||
background: 'red';}
|
8
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.graphql
vendored
Normal file
8
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.graphql
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
{
|
||||
baz {
|
||||
blah, ...name }
|
||||
bean{foo, blah,bleh}
|
||||
bar {
|
||||
...name
|
||||
}
|
||||
}
|
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.html
vendored
Normal file
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.html
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
<html>
|
||||
<head><title>foo</title></head>
|
||||
<body><h1>foo</h1></body></html>
|
1
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.js
vendored
Normal file
1
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.js
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
const a = () => { return 2; };
|
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.json
vendored
Normal file
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.json
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"name": "foo", "bar": "baz"
|
||||
}
|
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.less
vendored
Normal file
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.less
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
.redClass { background: 'red';}
|
||||
#redId {
|
||||
background: 'red';}
|
6
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.lua
vendored
Normal file
6
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.lua
vendored
Normal file
|
@ -0,0 +1,6 @@
|
|||
function deepcopy(orig)
|
||||
local orig_type = type(orig)
|
||||
local copy
|
||||
|
||||
return copy
|
||||
end
|
11
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.md
vendored
Normal file
11
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.md
vendored
Normal file
|
@ -0,0 +1,11 @@
|
|||
## foo
|
||||
Lorem ipsum dolor amet
|
||||
|
||||
|
||||
### bar
|
||||
|
||||
|
||||
|
||||
- a
|
||||
- b
|
||||
- c
|
4
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.php
vendored
Normal file
4
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.php
vendored
Normal file
|
@ -0,0 +1,4 @@
|
|||
<?php
|
||||
$a='a';
|
||||
|
||||
$b = $a. $a .' asda';
|
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.rb
vendored
Normal file
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.rb
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
for i in [1, 2, 3] do
|
||||
p i
|
||||
end
|
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.scss
vendored
Normal file
3
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.scss
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
.redClass { background: 'red';}
|
||||
#redId {
|
||||
background: 'red';}
|
1
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.ts
vendored
Normal file
1
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.ts
vendored
Normal file
|
@ -0,0 +1 @@
|
|||
const a: () => number = () => { return 2; };
|
14
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.vue
vendored
Normal file
14
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.vue
vendored
Normal 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>
|
19
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.xml
vendored
Normal file
19
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.xml
vendored
Normal 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 |
11
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.yaml
vendored
Normal file
11
dotfiles/.vim/plugged/vim-prettier/tests/fixtures/foo.yaml
vendored
Normal file
|
@ -0,0 +1,11 @@
|
|||
foo:
|
||||
|
||||
bar:
|
||||
|
||||
baz:
|
||||
|
||||
bleh: ./foo
|
||||
foobar: foobar
|
||||
args:
|
||||
|
||||
buildno: 1
|
126
dotfiles/.vim/plugged/vim-prettier/tests/formatting.test.js
Normal file
126
dotfiles/.vim/plugged/vim-prettier/tests/formatting.test.js
Normal 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));
|
35
dotfiles/.vim/plugged/vim-prettier/tests/vimrc
Normal file
35
dotfiles/.vim/plugged/vim-prettier/tests/vimrc
Normal 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'
|
3589
dotfiles/.vim/plugged/vim-prettier/yarn.lock
Normal file
3589
dotfiles/.vim/plugged/vim-prettier/yarn.lock
Normal file
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue