Page MenuHomePhorge

Correct PHPDoc @return value of methods that can return null
ClosedPublic

Authored by aklapper on Aug 24 2024, 20:41.
Tags
None
Referenced Files
F2898804: D25805.1737257449.diff
Sat, Jan 18, 03:30
F2898430: D25805.1737254476.diff
Sat, Jan 18, 02:41
F2878236: D25805.1737019659.diff
Wed, Jan 15, 09:27
F2878235: D25805.1737019658.diff
Wed, Jan 15, 09:27
F2878234: D25805.1737019657.diff
Wed, Jan 15, 09:27
F2877637: D25805.1737004238.diff
Wed, Jan 15, 05:10
F2877611: D25805.1737003467.diff
Wed, Jan 15, 04:57
F2871137: D25805.1736838282.diff
Mon, Jan 13, 07:04

Details

Summary

Make the PHPDoc @return say so when the method can also return null instead of an, array, string, or int.
(In case of getCommandHelp(), return an empty string as child implementations do return strings.)

Test Plan

Read the code; run static code analysis.

Diff Detail

Repository
rARC Arcanist
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

aklapper retitled this revision from Correct PHPDoc @return value that method can return null to Correct PHPDoc @return value of methods that can return null.Aug 25 2024, 12:47
src/workflow/ArcanistWorkflow.php
293 ↗(On Diff #2424)

I agree but probably we should update also something else, like this check that originally was a "not empty, not null, not objects without a toString()" check and instead now it's just "not null":

https://we.phorge.it/source/arcanist/browse/master/src/workflow/ArcanistWorkflow.php;995072b31fff5c7d77bcb353d25df819bfd3798a$157

(that line was changed during b50a646a3f49)

The question may be: is there any Workflow out of there without an help command?

If the answer is "maybe yes" let's update ArcanistWorkflow.php and adopt:

  • phutil_nonempty_stringlike() - if an help may return an object with __toString() (that renders text?)
  • phutil_nonempty_string() - if we are sure that it only returns null + string

Leave out special case src/workflow/ArcanistWorkflow.php for now

@valerio.bozzolan: Let's please move that case to a separate issue - thanks! :)

This revision is now accepted and ready to land.Sep 5 2024, 12:10
This revision was landed with ongoing or failed builds.Sep 5 2024, 12:55
This revision was automatically updated to reflect the committed changes.