PhpStorm 过度缩进多行函数

Ben*_*lan 5 phpstorm phpstorm-2017.2

我目前正在尝试配置 PhpStorm 以生成完全符合 PSR-2 的代码,但是它的格式化程序在包含具有多个参数的函数的长行上出错。

当我运行格式化程序时,它会转换:

return ($thisIsALongLine || functionCall($arg1, $arg2));
Run Code Online (Sandbox Code Playgroud)

进入这个:

return ($thisIsALongLine || functionCall(
        $arg1,
        $arg2
    ));
Run Code Online (Sandbox Code Playgroud)

然而,我想要的是这样的:

return ($thisIsALongLine || functionCall(
    $arg1,
    $arg2
));
Run Code Online (Sandbox Code Playgroud)

有谁知道哪个格式化程序选项告诉它在这种情况下进一步缩进多行函数调用?

注意:通常,我会将上面的格式设置为:

return ($thisIsALongLine
    || functionCall($arg1, $arg2));
Run Code Online (Sandbox Code Playgroud)

然而,这只是绕过了额外的缩进问题,我仍然需要在其他情况下修复这个问题。

编辑:这是包裹和大括号的状态,按照下面@LazyOne 的要求:

包裹和支架,第 1 部分 包裹和支架,第 2 部分

编辑 2: PhpStorm 的格式化程序无法正确处理的两种不同类型的行的示例。(免责声明:这是来自遗留系统的旧代码。)

首先,这个:

if ($validateBudget && $this->getFinancialPeriodService()->validateBudget($formModel->action, $formModel->estimatedBudget, $formModel->startDate, $formModel->endDate, $formModel->isFirstPeriod)) {
Run Code Online (Sandbox Code Playgroud)

变成这样:

if ($validateBudget && $this->getFinancialPeriodService()
    ->validateBudget($formModel->action, $formModel->estimatedBudget,
        $formModel->startDate, $formModel->endDate, $formModel->isFirstPeriod)) {
Run Code Online (Sandbox Code Playgroud)

当我根据上面的设置期望这个时:

if ($validateBudget && $this->getFinancialPeriodService()
    ->validateBudget(
        $formModel->action,
        $formModel->estimatedBudget,
        $formModel->startDate,
        $formModel->endDate,
        $formModel->isFirstPeriod
    )
) {
Run Code Online (Sandbox Code Playgroud)

其次,如果您启用链式方法的对齐,则:

if ($evaluation->getExpert() != NULL && ($evaluation->getExpert()->getStatusId() == Evaluation::STATUS_ASSIGNED || $evaluation->getEvaluationStage() == Evaluation::STAGE_PROPOSED && CoreDateUtils::dateIsPast($proposal->getCalendar()->getStage1StartDate()) == false || $evaluation->getEvaluationStage() == Evaluation::STAGE_IN_PROGRESS && CoreDateUtils::dateIsPast($proposal->getCalendar()->getStage2StartDate()) == false)) {
Run Code Online (Sandbox Code Playgroud)

重新格式化为:

if ($evaluation->getExpert() != null && ($evaluation->getExpert()
                                                    ->getStatusId() == Evaluation::STATUS_ASSIGNED || $evaluation->getEvaluationStage() == Evaluation::STAGE_PROPOSED && CoreDateUtils::dateIsPast($proposal->getCalendar()
                                                                                                                                                                                                            ->getStage1StartDate()) == false || $evaluation->getEvaluationStage() == Evaluation::STAGE_IN_PROGRESS && CoreDateUtils::dateIsPast($proposal->getCalendar()
                                                                                                                                                                                                                                                                                                                                                            ->getStage2StartDate()) == false)) {
Run Code Online (Sandbox Code Playgroud)

当我期望这个时:

if ($evaluation->getExpert() != null
    && ($evaluation->getExpert()->getStatusId() == Evaluation::STATUS_ASSIGNED
    || $evaluation->getEvaluationStage() == Evaluation::STAGE_PROPOSED
    && CoreDateUtils::dateIsPast($proposal->getCalendar()->getStage1StartDate()) == false
    || $evaluation->getEvaluationStage() == Evaluation::STAGE_IN_PROGRESS
    && CoreDateUtils::dateIsPast($proposal->getCalendar()->getStage2StartDate()) == false)
) {
Run Code Online (Sandbox Code Playgroud)

老实说,此时我怀疑格式化程序中存在错误,因此将向 JetBrains 开具票证,但是我将保留此票证,以防有人知道为什么它过度格式化/格式化不足。