prettier/prettier (prettier)
Compare Source
This version is a republished version of v2.8.7.
A bad version was accidentally published andit can't be unpublished, apologies for the churn.
Compare Source
diff
Allow multiple decorators on same getter/setter (#14584 by@fisker)
// InputclassA{ @​decorator()getfoo(){} @​decorator()setfoo(value){}}// Prettier 2.8.6SyntaxError:Decoratorscannotbeappliedtomultipleget/setaccessorsofthesamename.(5:3)3|getfoo(){}4|>5| @​decorator()|^^^^^^^^^^^^6|setfoo(value){}7|}// Prettier 2.8.7classA{ @​decorator()getfoo(){} @​decorator()setfoo(value){}}Compare Source
diff
Allow decorators on private members and class expressions (#14548 by@fisker)
// InputclassA{ @​decorator() #privateMethod(){}}// Prettier 2.8.5SyntaxError:Decoratorsarenotvalidhere.(2:3)1|classA{>2| @​decorator()|^^^^^^^^^^^^3| #privateMethod(){}4|}// Prettier 2.8.6classA{ @​decorator() #privateMethod(){}}Compare Source
diff
TypeScript 5.0 introduces two new syntactic features:
const modifiers for type parametersexport type * declarations
Add missing parentheses for decorator (#14393 by@fisker)
// InputclassPerson{ @​(myDecoratorArray[0])greet(){}}// Prettier 2.8.4classPerson{ @​myDecoratorArray[0]greet(){}}// Prettier 2.8.5classPerson{ @​(myDecoratorArray[0])greet(){}}Add parentheses forTypeofTypeAnnotation to improve readability (#14458 by@fisker)
// InputtypeA=(typeofnode.children)[];// Prettier 2.8.4typeA=typeofnode.children[];// Prettier 2.8.5typeA=(typeofnode.children)[];
Supportmax_line_length=off when parsing.editorconfig (#14516 by@josephfrazier)
If an .editorconfig file is in your project and it setsmax_line_length=off for the file you're formatting,
it will be interpreted as aprintWidth ofInfinity rather than being ignored
(which previously resulted in the defaultprintWidth of 80 being applied, if not overridden by Prettier-specific configuration).
<!-- Input --><divclassName='HelloWorld'title={`Youarevisitornumber${num}`}onMouseOver={onMouseOver}/><!-- Prettier 2.8.4 --><divclassName="HelloWorld"title={`Youarevisitornumber${num}`}onMouseOver={onMouseOver}/>;<!-- Prettier 2.8.5 --><divclassName="HelloWorld"title={`Youarevisitornumber${num}`}onMouseOver={onMouseOver}/>;Compare Source
diff
// InputtypeType={// commentreadonly[keyinFoo];};// Prettier 2.8.3typeType={readonly// comment[keyinFoo];};// Prettier 2.8.4typeType={// commentreadonly[keyinFoo];};Group params in opening block statements (#14067 by@jamescdavis)
This is a follow-up to#13930 to establish wrapping consistency between opening block statements and else blocks by
grouping params in opening blocks. This causes params to break to a new line together and not be split across lines
unless the length of params exceeds the print width. This also updates the else block wrapping to behave exactly the
same as opening blocks.
{{! Input }}{{#blockparamparamparamparamparamparamparamparamparamparamas |blockParam|}} Hello{{else block param param param param param param param param param param as |blockParam|}} There{{/block}}{{! Prettier 2.8.3 }}{{#blockparamparamparamparamparamparamparamparamparamparamas |blockParam|}} Hello{{else block paramparamparamparamparamparamparamparamparamparam}} There{{/block}}{{! Prettier 2.8.4 }}{{#blockparamparamparamparamparamparamparamparamparamparamas |blockParam|}} Hello{{else block param param param param param param param param param param as |blockParam|}} There{{/block}}InSapling SCM,.sl/ is the folder where it stores its state, analogous to.git/ in Git. It should be ignored in Prettier like the other SCM folders.
Recognize@satisfies in Closure-style type casts (#14262 by@fisker)
// Inputconsta=/** @​satisfies {Record<string, string>} */({hello:1337});constb=/** @​type {Record<string, string>} */({hello:1337});// Prettier 2.8.3consta=/** @​satisfies {Record<string, string>} */{hello:1337};constb=/** @​type {Record<string, string>} */({hello:1337});// Prettier 2.8.4consta=/** @​satisfies {Record<string, string>} */({hello:1337});constb=/** @​type {Record<string, string>} */({hello:1337});Fix parens in inferred function return types withextends (#14279 by@fisker)
// InputtypeFoo<T>=Textends((a)=>a is inferRextendsstring) ?R :never;// Prettier 2.8.3 (First format)typeFoo<T>=Textends(a)=>a is inferRextendsstring ?R :never;// Prettier 2.8.3 (Second format)SyntaxError:'?'expected.// Prettier 2.8.4typeFoo<T>=Textends((a)=>ais inferRextendsstring) ?R :never;
Compare Source
diff
Allow self-closing tags on custom elements (#14170 by@fisker)
SeeAngular v15.1.0 release note for details.
// Input<app-test/>// Prettier 2.8.2SyntaxError: Only void and foreign elements can be self closed "app-test" (1:1)> 1 |<app-test/> | ^^^^^^^^^ 2 |// Prettier 2.8.3<app-test/>
Compare Source
diff
<!-- Input-->We now don't strictly follow the release notes format suggested by[Keep a Changelog].[Keep a Changelog]:https://example.com/<!-- Prettier 2.8.1-->We now don't strictly follow the release notes format suggested by[Keep a Changelog].[keep a changelog]:https://example.com/<!--^^^^^^^^^^^^^^^^^^ lowercased--><!-- Prettier 2.8.2--><Sameasinput>
{{! Input }}<div /><div></div><custom-component /><custom-component></custom-component><i /><i></i><Component /><Component></Component>{{! Prettier 2.8.1 }}<div></div><div></div><custom-component></custom-component><custom-component></custom-component><i></i><i></i><Component /><Component />{{! Prettier 2.8.2 }}<div /><div></div><custom-component /><custom-component></custom-component><i /><i></i><Component /><Component />Allow custom "else if"-like blocks with block params (#13930 by@jamescdavis)
#13507 added support for custom block keywords used withelse, but failed to allow block params. This updates printer-glimmer to allow block params with custom "else if"-like blocks.
{{! Input }}{{#whenisAtWorkas |work|}} Ship that{{work}}!{{else when isReading as |book|}} You can finish{{book}} eventually...{{else}} Go to bed!{{/when}}{{! Prettier 2.8.1 }}{{#whenisAtWorkas |work|}} Ship that{{work}}!{{else when isReading}} You can finish{{book}} eventually...{{else}} Go to bed!{{/when}}{{! Prettier 2.8.2 }}{{#whenisAtWorkas |work|}} Ship that{{work}}!{{else when isReading as |book|}} You can finish{{book}} eventually...{{else}} Go to bed!{{/when}}Preserve empty lines between nested SCSS maps (#13931 by@jneander)
/* Input*/$map: ('one': ('key':'value', ),'two': ('key':'value', ),)/* Prettier 2.8.1*/$map: ('one': ('key':'value', ),'two': ('key':'value', ),)/* Prettier 2.8.2*/$map: ('one': ('key':'value', ),'two': ('key':'value', ),)Fix missing parentheses when an expression statement starts withlet[ (#14000,#14044 by@fisker,@thorn0)
// Input(let[0]=2);// Prettier 2.8.1let[0]=2;// Prettier 2.8.1 (second format)SyntaxError:Unexpectedtoken(1:5)>1|let[0]=2;|^2|// Prettier 2.8.2(let)[0]=2;
Fix semicolon duplicated at the end of LESS file (#14007 by@mvorisek)
// Input@​variable: { field: something;};// Prettier 2.8.1@​variable: { field: something;}; ;// Prettier 2.8.2@​variable: { field: something;};Fix no space after unary minus when followed by opening parenthesis in LESS (#14008 by@mvorisek)
// Input.unary_minus_single {margin:-(@​a);}.unary_minus_multi {margin:0-(@​a);}.binary_minus {margin:0- (@​a);}// Prettier 2.8.1.unary_minus_single {margin:- (@​a);}.unary_minus_multi {margin:0- (@​a);}.binary_minus {margin:0- (@​a);}// Prettier 2.8.2.unary_minus_single {margin:-(@​a);}.unary_minus_multi {margin:0-(@​a);}.binary_minus {margin:0- (@​a);}Do not change case of property name if inside a variable declaration in LESS (#14034 by@mvorisek)
// Input@​var: { preserveCase:0;};// Prettier 2.8.1@​var: { preservecase:0;};// Prettier 2.8.2@​var: { preserveCase:0;};Fix formatting for auto-accessors with comments (#14038 by@fisker)
// InputclassA{ @​dec()// commentaccessorb;}// Prettier 2.8.1classA{ @​dec()accessor// commentb;}// Prettier 2.8.1 (second format)classA{ @​dec()accessor;// commentb;}// Prettier 2.8.2classA{ @​dec()// commentaccessorb;}Add parentheses for TSTypeQuery to improve readability (#14042 by@onishi-kohei)
// Inputaas(typeofnode.children)[number]aas(typeofnode.children)[]aas((typeofnode.children)[number])[]// Prettier 2.8.1aastypeofnode.children[number];aastypeofnode.children[];aastypeofnode.children[number][];// Prettier 2.8.2aas(typeofnode.children)[number];aas(typeofnode.children)[];aas(typeofnode.children)[number][];
Fix displacing of comments in default switch case (#14047 by@thorn0)
It was a regression in Prettier 2.6.0.
// Inputswitch(state){default:result=state;// no changebreak;}// Prettier 2.8.1switch(state){default:// no changeresult=state;break;}// Prettier 2.8.2switch(state){default:result=state;// no changebreak;}Support type annotations on auto accessors viababel-ts (#14049 by@sosukesuzuki)
The bug that@babel/parser cannot parse auto accessors with type annotations has been fixed. So we now support it viababel-ts parser.
classFoo{ accessorprop:number;}Fix formatting of empty type parameters (#14073 by@fisker)
// Inputconstfoo:bar</* comment */> = () =>baz;// Prettier 2.8.1Error:Comment"comment"wasnotprinted.Pleasereportthiserror!// Prettier 2.8.2const foo:bar</* comment */>=()=>baz;
Add parentheses to head ofExpressionStatement instead of the whole statement (#14077 by@fisker)
// Input({}).toString.call(foo)==="[object Array]" ?foo.forEach(iterateArray) :iterateObject(foo);// Prettier 2.8.1({}.toString.call(foo)==="[object Array]" ?foo.forEach(iterateArray) :iterateObject(foo));// Prettier 2.8.2({}).toString.call(foo.forEach)==="[object Array]" ?foo.forEach(iterateArray) :iterateObject(foo);Fix comments after directive (#14081 by@fisker)
// Input"use strict"/* comment */;// Prettier 2.8.1 (with other js parsers except `babel`)Error:Comment"comment"wasnotprinted.Pleasereportthiserror!// Prettier 2.8.2<Sameasinput>
Fix formatting for comments inside JSX attribute (#14082 by@fisker)
// InputfunctionMyFunctionComponent(){<buttonlabel=/*old*/"new">button</button>}// Prettier 2.8.1Error:Comment"old"wasnotprinted.Pleasereportthiserror!// Prettier 2.8.2functionMyFunctionComponent(){<buttonlabel=/*old*/"new">button</button>;}Quote numeric keys for json-stringify parser (#14083 by@fisker)
// Input{0:'value'}// Prettier 2.8.1{0:"value"}// Prettier 2.8.2{"0":"value"}Fix removing commas from function arguments in maps (#14089 by@sosukesuzuki)
/* Input*/$foo:map-fn( ("#{prop}":inner-fn($first,$second), ));/* Prettier 2.8.1*/$foo:map-fn(("#{prop}":inner-fn($first$second)));/* Prettier 2.8.2*/$foo:map-fn( ("#{prop}":inner-fn($first,$second), ));Do not insert space in LESS property access (#14103 by@fisker)
// Inputa {color: @​colors[@​white];}// Prettier 2.8.1a {color: @​colors[ @​white];}// Prettier 2.8.2<Same asinput>Compare Source
diff
// Input$display-breakpoints:map-deep-merge( ("print-only":"only print","screen-only":"only screen","xs-only":"only screen and (max-width:#{map-get($grid-breakpoints,"sm")-1})", ),$display-breakpoints);// Prettier 2.8.0$display-breakpoints:map-deep-merge( ("print-only":"only print","screen-only":"only screen","xs-only":"only screen and (max-width:#{map-get($grid-breakpoints," sm")-1})", ),$display-breakpoints);// Prettier 2.8.1$display-breakpoints:map-deep-merge( ("print-only":"only print","screen-only":"only screen","xs-only":"only screen and (max-width:#{map-get($grid-breakpoints,"sm")-1})", ),$display-breakpoints);Support forAuto Accessors Syntax landed in TypeScript 4.9.
(Doesn't work well withbabel-ts parser)
classFoo{ accessorfoo:number=3;}Compare Source
diff
🔗Release Notes
Compare Source
diff
Keep useful empty lines in description (#13013 by@chimurai)
Compare Source
"""
First line
Second Line
"""
type Person {
name: String
}
Compare Source
diff
Fix LESS/SCSS format error (#12536 by@fisker)
// Input.background-gradient(@​cut) {background:linear-gradient(toright, @​white0%, @​white (@​cut -0.01%), @​portal-background @​cut, @​portal-background100% );}// Prettier 2.6.1TypeError: Cannot read properties of undefined (reading'endOffset')// Prettier 2.6.2.background-gradient(@​cut) {background:linear-gradient(toright, @​white0%, @​white (@​cut -0.01%), @​portal-background @​cut, @​portal-background100% );}Fixes bugs when parsing following valid code:
constelement=<p>{/w/.test(s)}</p>;classAextendsB{ #privateMethod(){super.method();}}Compare Source
diff
Ignoreloglevel when printing information (#12477 by@fisker)
Compare Source
prettier --loglevel silent --find-config-path index.js
Compare Source
diff
Improve formatting for empty tuple types (#11884 by@sosukesuzuki)
// InputtypeFoo=Fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooextends[] ?Foo3 :Foo4;// Prettier 2.5.0typeFoo=Fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooextends[] ?Foo3 :Foo4;// Prettier 2.5.0 (tailingCommma = all)// Invalid TypeScript codetypeFoo=Fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooextends[,] ?Foo3 :Foo4;// Prettier 2.5.1typeFoo=Fooooooooooooooooooooooooooooooooooooooooooooooooooooooooooextends[] ?Foo3 :Foo4;
Fix compatibility with Jest inline snapshot test (#11892 by@fisker)
A internal change in Prettier@v2.5.0 accidentally breaks the Jest inline snapshot test.
Support Glimmer's named blocks (#11899 by@duailibe)
Prettier already supported this feature, but it converted empty named blocks to self-closing, which is not supported by the Glimmer compiler.
See:Glimmer's named blocks.
// Input<Component> <:named></:named></Component>// Prettier 2.5.0<Component> <:named /></Component>// Prettier 2.5.1<Component> <:named></:named></Component>
Compare Source
diff
🔗Release Notes
Compare Source
diff
// Input@​forward "library" as btn-*;// Prettier 2.4.0@​forward "library" as btn-*;// Prettier 2.4.1@​forward "library" as btn-*;
A new--debug-print-ast CLI flag for debugging.
Compare Source
diff
🔗Release Notes
Compare Source
diff
Fix failure on dir with trailing slash (#11000 by@fisker)
Compare Source
$ prettier . -l
1.js
$ prettier ./ -l
[error] No supported files were found in the directory: "./".
Compare Source
diff
🔗Release Notes
Uh oh!
There was an error while loading.Please reload this page.
This PR contains the following updates:
2.2.1->2.8.8Release Notes
prettier/prettier (prettier)
v2.8.8Compare Source
This version is a republished version of v2.8.7.
A bad version was accidentally published andit can't be unpublished, apologies for the churn.
v2.8.7Compare Source
diff
Allow multiple decorators on same getter/setter (#14584 by@fisker)
v2.8.6Compare Source
diff
Allow decorators on private members and class expressions (#14548 by@fisker)
v2.8.5Compare Source
diff
Support TypeScript 5.0 (#14391 by@fisker,#13819 by@fisker,@sosukesuzuki)
TypeScript 5.0 introduces two new syntactic features:
constmodifiers for type parametersexport type *declarationsAdd missing parentheses for decorator (#14393 by@fisker)
Add parentheses for
TypeofTypeAnnotationto improve readability (#14458 by@fisker)Support
max_line_length=offwhen parsing.editorconfig(#14516 by@josephfrazier)If an .editorconfig file is in your project and it sets
max_line_length=offfor the file you're formatting,it will be interpreted as a
printWidthofInfinityrather than being ignored(which previously resulted in the default
printWidthof 80 being applied, if not overridden by Prettier-specific configuration).v2.8.4Compare Source
diff
Fix leading comments in mapped types with
readonly(#13427 by@thorn0,@sosukesuzuki)Group params in opening block statements (#14067 by@jamescdavis)
This is a follow-up to#13930 to establish wrapping consistency between opening block statements and else blocks by
grouping params in opening blocks. This causes params to break to a new line together and not be split across lines
unless the length of params exceeds the print width. This also updates the else block wrapping to behave exactly the
same as opening blocks.
Ignore files in
.sl/(#14206 by@bolinfest)InSapling SCM,
.sl/is the folder where it stores its state, analogous to.git/in Git. It should be ignored in Prettier like the other SCM folders.Recognize
@satisfiesin Closure-style type casts (#14262 by@fisker)Fix parens in inferred function return types with
extends(#14279 by@fisker)v2.8.3Compare Source
diff
Allow self-closing tags on custom elements (#14170 by@fisker)
SeeAngular v15.1.0 release note for details.
v2.8.2Compare Source
diff
Don't lowercase link references (#13155 by@DerekNonGeneric &@fisker)
Preserve self-closing tags (#13691 by@dcyriller)
Allow custom "else if"-like blocks with block params (#13930 by@jamescdavis)
#13507 added support for custom block keywords used with
else, but failed to allow block params. This updates printer-glimmer to allow block params with custom "else if"-like blocks.Preserve empty lines between nested SCSS maps (#13931 by@jneander)
Fix missing parentheses when an expression statement starts with
let[(#14000,#14044 by@fisker,@thorn0)Fix semicolon duplicated at the end of LESS file (#14007 by@mvorisek)
Fix no space after unary minus when followed by opening parenthesis in LESS (#14008 by@mvorisek)
Do not change case of property name if inside a variable declaration in LESS (#14034 by@mvorisek)
Fix formatting for auto-accessors with comments (#14038 by@fisker)
Add parentheses for TSTypeQuery to improve readability (#14042 by@onishi-kohei)
Fix displacing of comments in default switch case (#14047 by@thorn0)
It was a regression in Prettier 2.6.0.
Support type annotations on auto accessors via
babel-ts(#14049 by@sosukesuzuki)The bug that
@babel/parsercannot parse auto accessors with type annotations has been fixed. So we now support it viababel-tsparser.Fix formatting of empty type parameters (#14073 by@fisker)
Add parentheses to head of
ExpressionStatementinstead of the whole statement (#14077 by@fisker)Fix comments after directive (#14081 by@fisker)
Fix formatting for comments inside JSX attribute (#14082 by@fisker)
Quote numeric keys for json-stringify parser (#14083 by@fisker)
Fix removing commas from function arguments in maps (#14089 by@sosukesuzuki)
Do not insert space in LESS property access (#14103 by@fisker)
v2.8.1Compare Source
diff
Fix SCSS map in arguments (#9184 by@agamkrbit)
Support auto accessors syntax (#13919 by@sosukesuzuki)
Support forAuto Accessors Syntax landed in TypeScript 4.9.
(Doesn't work well with
babel-tsparser)v2.8.0Compare Source
diff
🔗Release Notes
v2.7.1Compare Source
diff
Keep useful empty lines in description (#13013 by@chimurai)
v2.7.0Compare Source
"""
First line
Second Line
"""
type Person {
name: String
}
v2.6.2Compare Source
diff
Fix LESS/SCSS format error (#12536 by@fisker)
Update
meriyahto fix several bugs (#12567 by@fisker, fixes inmeriyahby@3cp)Fixes bugs when parsing following valid code:
v2.6.1Compare Source
diff
Ignore
loglevelwhen printing information (#12477 by@fisker)v2.6.0Compare Source
prettier --loglevel silent --find-config-path index.js
v2.5.1Compare Source
diff
Improve formatting for empty tuple types (#11884 by@sosukesuzuki)
Fix compatibility with Jest inline snapshot test (#11892 by@fisker)
A internal change in Prettier@v2.5.0 accidentally breaks the Jest inline snapshot test.
Support Glimmer's named blocks (#11899 by@duailibe)
Prettier already supported this feature, but it converted empty named blocks to self-closing, which is not supported by the Glimmer compiler.
See:Glimmer's named blocks.
v2.5.0Compare Source
diff
🔗Release Notes
v2.4.1Compare Source
diff
Fix wildcard syntax in
@forward(#11482) (#11487 by@niksy)Add new CLI option
debug-print-ast(#11514 by@sosukesuzuki)A new
--debug-print-astCLI flag for debugging.v2.4.0Compare Source
diff
🔗Release Notes
v2.3.2Compare Source
diff
Fix failure on dir with trailing slash (#11000 by@fisker)
v2.3.1Compare Source
$ prettier . -l
1.js
$ prettier ./ -l
[error] No supported files were found in the directory: "./".
v2.3.0Compare Source
diff
🔗Release Notes
Configuration
📅Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦Automerge: Enabled.
♻Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.
🔕Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated byMend Renovate. View therepository job log.