Change getData() so that it can be mixed instead of array #77
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
🔀 Pull Request
What does this PR do?
The constructor itself allows
$data
to be mixed and the functions in AccessHelper has various conditional statements to process the data depending on whether it is an array or an implementation ofArrayAccess
. However,getData()
is explicitly typed to return an array which means any attempts to get the source object after creating aJSONPath
of it will cause aTypeError
to be raised. ChanginggetData()
to return mixed instead of array will help fix this inconsistency.Thank you for reviewing and considering this change.
Test Plan
JSONPath/tests/JSONPathArrayAccessTest.php
Lines 27 to 30 in 3a6108a
If you just add that one line the test will no longer run. This demonstrates the issue that I have described above where you can create a
JSONPath
but then callinggetData()
again to retrieve the original content will fail.Related PRs and Issues
None that I am aware of.