在 vs code 使用 php cs fixer 進行 coding style 的格式修正
在 vs code 中,使用 PSR1、PSR2 及 Symfony 的 Coding Style 進行格式修正。
安裝
- 在 command line 使用 homebrew 安裝 php cs fixer - 1 - $ brew install php-cs-fixer 
- 在 vs code 安裝 extension - 由 junstyle 開發的 php cs fixer,extension_id - junstyle.php-cs-fixer
- 其他安裝方式可參考 Install guide 
設定
- 快速鍵 - cmd + shift + p後輸入- workspace settings貼上- 1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16- { 
 "php.suggest.basic": false,
 "php.validate.executablePath": "php",
 "php-cs-fixer.executablePath": "php-cs-fixer",
 "php-cs-fixer.executablePathWindows": "", //eg: php-cs-fixer.bat
 "php-cs-fixer.onsave": false,
 "php-cs-fixer.rules": "",
 "php-cs-fixer.config": ".php_cs",
 "php-cs-fixer.allowRisky": false,
 "php-cs-fixer.pathMode": "override",
 "php-cs-fixer.exclude": [],
 "php-cs-fixer.autoFixByBracket": true,
 "php-cs-fixer.autoFixBySemicolon": false,
 "php-cs-fixer.formatHtml": false,
 "php-cs-fixer.documentFormattingProvider": true,
 }- 說明: - "php-cs-fixer.onsave": true,: true 為存檔時即執行。我個人習慣是設定成 false,在確定程式沒問題後才執行檢查,因此必須按右鍵,再從選單中點擊「Format Document」進行檢查。
- "php-cs-fixer.rules": "",: 留空字串
- "php-cs-fixer.config": ".php_cs",: 使用 project root path 下的 config file 最為 formating 基準
 
- 在 project root 新增檔案 - .php_cs,內容如下- 1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 $header = <<<'EOF'
 This file is part of PHP CS Fixer.
 (c) Fabien Potencier <fabien@symfony.com>
 Dariusz Rumiński <dariusz.ruminski@gmail.com>
 This source file is subject to the MIT license that is bundled
 with this source code in the file LICENSE.
 EOF;
 $finder = PhpCsFixer\Finder::create()
 ->exclude('tests/Fixtures')
 ->in(__DIR__)
 ;
 $config = PhpCsFixer\Config::create()
 ->setRiskyAllowed(true)
 ->setRules([
 '@PHP56Migration' => true,
 '@PHPUnit60Migration:risky' => true,
 '@PSR1' => true,
 '@PSR2' => true,
 '@Symfony' => true,
 '@Symfony:risky' => true,
 'align_multiline_comment' => true,
 'array_indentation' => true,
 'array_syntax' => ['syntax' => 'short'],
 'blank_line_before_statement' => true,
 'binary_operator_spaces' => [
 'align_double_arrow' => true,
 'align_equals' => false,
 ],
 'combine_consecutive_issets' => true,
 'combine_consecutive_unsets' => true,
 'comment_to_phpdoc' => true,
 'compact_nullable_typehint' => true,
 'concat_space' => ['spacing' => 'one'],
 'escape_implicit_backslashes' => true,
 'explicit_indirect_variable' => true,
 'explicit_string_variable' => true,
 'final_internal_class' => true,
 'fully_qualified_strict_types' => true,
 'function_to_constant' => ['functions' => ['get_class', 'get_called_class', 'php_sapi_name', 'phpversion', 'pi']],
 //'header_comment' => ['header' => $header],
 'heredoc_to_nowdoc' => true,
 'increment_style' => false,
 'list_syntax' => ['syntax' => 'short'],
 'logical_operators' => true,
 'method_argument_space' => ['on_multiline' => 'ensure_fully_multiline'],
 'method_chaining_indentation' => true,
 'multiline_comment_opening_closing' => true,
 'no_alternative_syntax' => true,
 'no_binary_string' => true,
 'no_extra_blank_lines' => ['tokens' => ['break', 'continue', 'extra', 'return', 'throw', 'use', 'parenthesis_brace_block', 'square_brace_block', 'curly_brace_block']],
 'no_null_property_initialization' => true,
 'no_short_echo_tag' => true,
 'no_superfluous_elseif' => true,
 'no_unneeded_curly_braces' => true,
 'no_unneeded_final_method' => true,
 'no_unreachable_default_argument_value' => true,
 'no_unset_on_property' => true,
 'no_useless_else' => true,
 'no_useless_return' => true,
 'ordered_class_elements' => true,
 'ordered_imports' => true,
 'php_unit_internal_class' => true,
 'php_unit_ordered_covers' => true,
 'php_unit_set_up_tear_down_visibility' => true,
 'php_unit_strict' => true,
 'php_unit_test_annotation' => true,
 'php_unit_test_case_static_method_calls' => ['call_type' => 'this'],
 'php_unit_test_class_requires_covers' => true,
 'phpdoc_add_missing_param_annotation' => true,
 'phpdoc_order' => true,
 'phpdoc_trim_consecutive_blank_line_separation' => true,
 'phpdoc_types_order' => true,
 'return_assignment' => true,
 'semicolon_after_instruction' => true,
 'single_line_comment_style' => true,
 'strict_comparison' => true,
 'strict_param' => true,
 'string_line_ending' => true,
 'ternary_operator_spaces' => true,
 'trim_array_spaces' => true,
 'unary_operator_spaces' => true,
 'yoda_style' => true,
 'whitespace_after_comma_in_array' => true,
 ])
 ->setFinder($finder)
 ;
 // special handling of fabbot.io service if it's using too old PHP CS Fixer version
 if (false !== getenv('FABBOT_IO')) {
 try {
 PhpCsFixer\FixerFactory::create()
 ->registerBuiltInFixers()
 ->registerCustomFixers($config->getCustomFixers())
 ->useRuleSet(new PhpCsFixer\RuleSet($config->getRules()));
 } catch (PhpCsFixer\ConfigurationException\InvalidConfigurationException $e) {
 $config->setRules([]);
 } catch (UnexpectedValueException $e) {
 $config->setRules([]);
 } catch (InvalidArgumentException $e) {
 $config->setRules([]);
 }
 }
 return $config;- 說明: - 加入 '@PSR1' => true,及'@Symfony' => true,
 
- 加入 
- 重新啟動 vs code(建議使用 - cmd + Q,再重新啟動)
- 編輯檔案後存檔,即自動執行 php-cs-fixer 進行 coding style 修正