Comments (4)
@paragonie-scott fixed that error here: e59dba3
from psalm.
Short answer
To get rid of this particular issue, add <FailedTypeResolution errorLevel="suppress" />
to the <issueHandlers>
block in your Psalm config.
Longer answer
Psalm is treating the above as directly equivalent to
function foo(string $foo)
{
if (!is_string($foo)) {
throw new TypeError("test");
}
}
In the above function, the exception cannot ever be thrown, and so Psalm emits an issue when trying to change a variable to an impossible type.
Unfortunately, Psalm doesn't record whether a variable's type is asserted in a docblock or in a more iron-clad fashion (e.g. a parameter type or instanceof
check), and I want to add that in the near future. So I'll keep this open until that's fixed.
from psalm.
In Vimeo's PHP 5 codebase we have <FailedTypeResolution errorLevel="info" />
so we can see where these issues can crop up, but they don't prevent Psalm running succesfully.
from psalm.
Other failures:
ERROR: TooManyArguments - src/Core/Util.php:121 - Too many arguments for method pack
$hex .= pack(
'CC',
(55 + $b + ((($b - 10) >> 8) & ~6)),
(55 + $c + ((($c - 10) >> 8) & ~6))
);
Well, pack()
can actually accept an arbitrary number of parameters.
from psalm.
Related Issues (20)
- Encapsed strings should return non-falsy-string if non-falsy like concat HOT 1
- Encapsed non-literal non-empty/falsy strings always return generic string HOT 1
- Encapsed string cast loses literal type information unlike cast HOT 1
- Encapsed string loses literal string details for unions unlike concat HOT 1
- int-range behaves different than literal int even when identical HOT 1
- Report error for float used with modulo HOT 1
- Psalm PHP notice when using modulo, bitwise or,... on non-int HOT 1
- Suppress `MissingClassConstType` if the class is `final` HOT 1
- Suggestion: Allow empty `<errorLevel>` in `psalm.xml` (i.e. suppress everywhere) HOT 2
- PHP 8.2 has PHP Error: Creation of dynamic property PhpParser\Node\Stmt\... HOT 4
- CI: phpunit should fail on deprecated notices HOT 1
- TooManyArguments false positive HOT 1
- `MissingClassConstType` error still appears when specify type annotation `/** @var int **/`
- Wrong `MixedArgumentTypeCoercion` HOT 1
- int range returns incorrect result for pow HOT 1
- Psalm is unable to detect type of object shape when trying to call callable property. HOT 1
- InvalidArgument error introduced in 5.24 HOT 2
- ArrayAccess with nullable value and ?? gives PossiblyNullReference HOT 3
- FalsePositive ImpureVariable in constructor HOT 1
- Support declaring known type variadic named arguments HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from psalm.