In method arguments and method call, there MUST NOT be a space before each comma and there MUST be one space after each comma. Argument lists MAY be split across multiple lines, where each subsequent line is indented once. When doing so, the first item in the list MUST be on the next line, and there MUST be only one argument per line.
This fixer covers rules defined in PSR2 ¶4.4, ¶4.6.
Whether the whitespace between heredoc end and comma should be removed.
Allowed types: bool
Default value: false
Defines how to handle argument attributes when function definition is multiline.
Allowed values: 'ignore'
, 'same_line'
and 'standalone'
Default value: 'standalone'
Whether keep multiple spaces after comma.
Allowed types: bool
Default value: false
Defines how to handle function arguments lists that contain newlines.
Allowed values: 'ensure_fully_multiline'
, 'ensure_single_line'
and 'ignore'
Default value: 'ensure_fully_multiline'
Default configuration.
--- Original
+++ New
<?php
-function sample($a=10,$b=20,$c=30) {}
-sample(1, 2);
+function sample($a=10, $b=20, $c=30) {}
+sample(1, 2);
With configuration: ['keep_multiple_spaces_after_comma' => false]
.
--- Original
+++ New
<?php
-function sample($a=10,$b=20,$c=30) {}
-sample(1, 2);
+function sample($a=10, $b=20, $c=30) {}
+sample(1, 2);
With configuration: ['keep_multiple_spaces_after_comma' => true]
.
--- Original
+++ New
<?php
-function sample($a=10,$b=20,$c=30) {}
+function sample($a=10, $b=20, $c=30) {}
sample(1, 2);
With configuration: ['on_multiline' => 'ensure_fully_multiline']
.
--- Original
+++ New
<?php
-function sample($a=10,
- $b=20,$c=30) {}
-sample(1,
- 2);
+function sample(
+ $a=10,
+ $b=20,
+ $c=30
+) {}
+sample(
+ 1,
+ 2
+);
With configuration: ['on_multiline' => 'ensure_single_line']
.
--- Original
+++ New
<?php
-function sample(
- $a=10,
- $b=20,
- $c=30
-) {}
-sample(
- 1,
- 2
-);
+function sample($a=10, $b=20, $c=30) {}
+sample(1, 2);
With configuration: ['on_multiline' => 'ensure_fully_multiline', 'keep_multiple_spaces_after_comma' => true]
.
--- Original
+++ New
<?php
-function sample($a=10,
- $b=20,$c=30) {}
-sample(1,
- 2);
+function sample(
+ $a=10,
+ $b=20,
+ $c=30
+) {}
+sample(
+ 1,
+ 2
+);
sample('foo', 'foobarbaz', 'baz');
sample('foobar', 'bar', 'baz');
With configuration: ['on_multiline' => 'ensure_fully_multiline', 'keep_multiple_spaces_after_comma' => false]
.
--- Original
+++ New
<?php
-function sample($a=10,
- $b=20,$c=30) {}
-sample(1,
- 2);
-sample('foo', 'foobarbaz', 'baz');
-sample('foobar', 'bar', 'baz');
+function sample(
+ $a=10,
+ $b=20,
+ $c=30
+) {}
+sample(
+ 1,
+ 2
+);
+sample('foo', 'foobarbaz', 'baz');
+sample('foobar', 'bar', 'baz');
With configuration: ['on_multiline' => 'ensure_fully_multiline', 'attribute_placement' => 'ignore']
.
--- Original
+++ New
<?php
-function sample(#[Foo] #[Bar] $a=10,
- $b=20,$c=30) {}
-sample(1, 2);
+function sample(
+ #[Foo] #[Bar] $a=10,
+ $b=20,
+ $c=30
+) {}
+sample(1, 2);
With configuration: ['on_multiline' => 'ensure_fully_multiline', 'attribute_placement' => 'same_line']
.
--- Original
+++ New
<?php
-function sample(#[Foo]
- #[Bar]
- $a=10,
- $b=20,$c=30) {}
-sample(1, 2);
+function sample(
+ #[Foo] #[Bar] $a=10,
+ $b=20,
+ $c=30
+) {}
+sample(1, 2);
With configuration: ['on_multiline' => 'ensure_fully_multiline', 'attribute_placement' => 'standalone']
.
--- Original
+++ New
<?php
-function sample(#[Foo] #[Bar] $a=10,
- $b=20,$c=30) {}
-sample(1, 2);
+function sample(
+ #[Foo]
+ #[Bar]
+ $a=10,
+ $b=20,
+ $c=30
+) {}
+sample(1, 2);
With configuration: ['after_heredoc' => true]
.
--- Original
+++ New
<?php
sample(
<<<EOD
foo
- EOD
- ,
+ EOD,
'bar'
);
The rule is part of the following rule sets:
@PER-CS1.0 with config:
['attribute_placement' => 'ignore', 'on_multiline' => 'ensure_fully_multiline']
@PHP73Migration with config:
['after_heredoc' => true]
@PHP74Migration with config:
['after_heredoc' => true]
@PHP80Migration with config:
['after_heredoc' => true]
@PHP81Migration with config:
['after_heredoc' => true]
@PHP82Migration with config:
['after_heredoc' => true]
@PHP83Migration with config:
['after_heredoc' => true]
@PHP84Migration with config:
['after_heredoc' => true]
@PSR2 with config:
['attribute_placement' => 'ignore', 'on_multiline' => 'ensure_fully_multiline']
@PSR12 with config:
['attribute_placement' => 'ignore', 'on_multiline' => 'ensure_fully_multiline']
@PhpCsFixer with config:
['on_multiline' => 'ensure_fully_multiline']
@Symfony with config:
['on_multiline' => 'ignore']
- Fixer class: PhpCsFixer\Fixer\FunctionNotation\MethodArgumentSpaceFixer
- Test class: PhpCsFixer\Tests\Fixer\FunctionNotation\MethodArgumentSpaceFixerTest
The test class defines officially supported behaviour. Each test case is a part of our backward compatibility promise.