You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When using static analysis using (for example) PHPStan, on code like this:
//All-day event has the date property setif (is_string( $calendarEvent->getStart()->date)) {
//Process all-day event
}
} elseif (is_string( $calendarEvent->getStart()->dateTime)) {
//event is not all-day-even
}
This will result in an error like:
Elseif branch is unreachable because previous condition is always true.
Describe the solution you'd like
It would be better to use PHPDoc to indicate that the property can be null, for example
I am not sure how this will work across all APIs - what in the discovery doc decides if a field is nullable? There is a "required" keyword, but it's for the Resource classes making the requests, and not for the objects which are sent in the request.
So I believe the answer is that simply adding |null would be sufficient.
This library now has minimum PHP version support for PHP 7.4 (#2854), so nullable return types can be added. Can we contribute those kind of changes @bshaffer, or is the repo completely auto generated?
Related / follow-up of #172
Is your feature request related to a problem? Please describe.
Currently some classes have properties that
For example:
google-api-php-client-services/src/Calendar/EventDateTime.php
Lines 23 to 25 in dbd6041
And
google-api-php-client-services/src/Calendar/EventDateTime.php
Lines 42 to 48 in dbd6041
When using static analysis using (for example) PHPStan, on code like this:
This will result in an error like:
Elseif branch is unreachable because previous condition is always true.
Describe the solution you'd like
It would be better to use PHPDoc to indicate that the property can be null, for example
Describe alternatives you've considered
For PHP versions that support typed properties and return types, the PHPDoc can be omitted:
But this library supports PHP
>=5.6
, so this is probably not an option yet: https://github.com/googleapis/google-api-php-client-services/blob/main/composer.json#L9The text was updated successfully, but these errors were encountered: