Page MenuHomePhorge

Fix PHP 8.1 "strlen(null)" exceptions handling empty comment metadata in PhabricatorEditEngine
ClosedPublic

Authored by aklapper on Jun 24 2024, 13:15.
Tags
None
Referenced Files
F3340663: D25699.1743640994.diff
Wed, Apr 2, 00:43
F3338201: D25699.1743600450.diff
Tue, Apr 1, 13:27
F3334050: D25699.1743544000.diff
Mon, Mar 31, 21:46
F3331900: D25699.1743514707.diff
Mon, Mar 31, 13:38
F3330903: D25699.1743496789.diff
Mon, Mar 31, 08:39
F3330313: D25699.1743487304.diff
Mon, Mar 31, 06:01
F3321019: D25699.1743342687.diff
Sat, Mar 29, 13:51
F3314821: D25699.1743233912.diff
Fri, Mar 28, 07:38

Details

Summary

strlen() was used in Phabricator to check if a generic value is a non-empty string.
This behavior is deprecated since PHP 8.1. Phorge adopts phutil_nonempty_string() as a replacement.

Note: this may highlight other absurd input values that might be worth correcting
instead of just ignoring. If phutil_nonempty_string() throws an exception in your
instance, report it to Phorge to evaluate and fix that specific corner case.

ERROR 8192: strlen(): Passing null to parameter #1 ($string) of type string is deprecated at [/var/www/html/phorge/phorge/src/applications/transactions/editengine/PhabricatorEditEngine.php:1923]
ERROR 8192: strlen(): Passing null to parameter #1 ($string) of type string is deprecated at [/var/www/html/phorge/phorge/src/applications/transactions/editengine/PhabricatorEditEngine.php:2023]

Closes T15864

Test Plan

Diff Detail

Repository
rP Phorge
Branch
T15864strlenEmptyComment (branched from master)
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 1368
Build 1368: arc lint + arc unit