3

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

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

return ($thisIsALongLine || functionCall($arg1, $arg2));

进入这个:

return ($thisIsALongLine || functionCall(
        $arg1,
        $arg2
    ));

但是,我想要的是这样的:

return ($thisIsALongLine || functionCall(
    $arg1,
    $arg2
));

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

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

return ($thisIsALongLine
    || functionCall($arg1, $arg2));

但是,这只是绕过了额外的缩进问题,我仍然需要针对其他情况进行修复。

编辑:这是包装和大括号的状态,如下@LazyOne 所要求:

包装和大括号,第 1 部分 包装和大括号,第 2 部分

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

首先,这个:

if ($validateBudget && $this->getFinancialPeriodService()->validateBudget($formModel->action, $formModel->estimatedBudget, $formModel->startDate, $formModel->endDate, $formModel->isFirstPeriod)) {

变成这样:

if ($validateBudget && $this->getFinancialPeriodService()
    ->validateBudget($formModel->action, $formModel->estimatedBudget,
        $formModel->startDate, $formModel->endDate, $formModel->isFirstPeriod)) {

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

if ($validateBudget && $this->getFinancialPeriodService()
    ->validateBudget(
        $formModel->action,
        $formModel->estimatedBudget,
        $formModel->startDate,
        $formModel->endDate,
        $formModel->isFirstPeriod
    )
) {

其次,如果您在链式方法上启用对齐,那么:

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)) {

被重新格式化为:

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)) {

当我期望这个时:

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)
) {

老实说,此时我怀疑格式化程序中存在错误,因此将使用 JetBrains 打开一张票,但是我会保持打开状态,以防有人知道它为什么会过度/不足格式化。

4

0 回答 0