Download the PHP package lifespikes/scramble-match-stmt without Composer
On this page you can find all versions of the php package lifespikes/scramble-match-stmt. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download lifespikes/scramble-match-stmt
More information about lifespikes/scramble-match-stmt
Files in lifespikes/scramble-match-stmt
Package scramble-match-stmt
Short Description Sample extension for Scramble usage with PhpParser
License MIT
Informations about the package scramble-match-stmt
scramble-match-stmt
This Scramble extension was made as an experiment of how usable PhpParser may be when building extensions.
In essence, it allows you to scan JsonResource
classes whose toArray
features a dynamic return type through a match
statement.
Install
Then, in your scramble.php
config file:
Analyzing the code
Scramble gives us the FQN of the type being analyzed, using ReflectionClass
, we get the file path of the class.
We fetch the contents and use Scramble's FileParser
to get the AST of the file we intend to analyze. This returns a FileParserResult
object that is essentially a PhpParser
instance.
Once we have a file, we use the getMethod
method to help us get to the toArray
method easier.
Then, we traverse through the nodes:
- First we find the
return
statement - Then the
match
- And then we get the first
MatchArm_
Lastly, we get the body of the MatchArm_
and verify it is an array.
Casting to Scramble types
We had to go digging and used code from the MethodAnalyzer
and ArrayItemHandler
classes.
Then we mimicked some of their behavior and re-used other internal classes like Scope
and TypeHelper
to cast our PhpParser nodes to Scramble types.
Lastly, we used the TypeTransformer
to turn everything into an usable OpenAPI Schema.
More info?
Read the code, and some comments I sprinkled around for more details.