Issue with calling `JSON::Pure::Parser` in new releases
Closed this issue · 6 comments
Following earlier issues with using json-pure
alongside json
we removed the json-pure
gem from our dependencies as it was judged that it was no longer needed.
As part of this we left a line in place JSON::Pure::Parser
as the output that it givs is superior for our purposes.
require 'json/pure'
JSON.parser = JSON::Pure::Parser
Prior to the newest release of the json gem this worked without issues, however as of 2.8.0
this has begun causing errors and I wanted to confirm whether this was a bug, or expected.
Failure/Error: require 'json/pure'
LoadError:
cannot load such file -- json/pure
JSON::Pure
no longer exist as of 2.8.0
.
As part of this we left a line in place JSON::Pure::Parser as the output that it givs is superior for our purposes.
Could you detail what you mean here? As long as pure
existed we tried to have it as consistent as possible with Ext
. How was the output different?
TBH I am not entirely sure, I was not part of the team when that decision was made and my knowledge of it comes fro a large warning comment in the code.
If it has been removed though, will work around this and see what I can do.
Thanks for replying fast.
If for some reason JSON.parse
cause you issues, I'm interested in knowing what's wrong.
And if you have to work around it, it's probably not hard to vendor the old Pure::Parser implementation in your code base.
The original code was about 7 years ago, so likely that the differences have disappeared since.
Hey, just getting back to this because you seemed interested, but the main change was in how the data was passed back, when checking for errors the JSON:Pure::Parser gave us this:
\Aexpected ':' in object
while the JSON::Ext::Parser gives us this:
unexpected token at '{\\\"test\\\"\\\": \\\"value\\\"}'
Ah I see. That was for the different error messages. To be fair, the Ext::Parser
error messages could certainly be improve.
Thanks for the info.