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
I've written a gem that is using MultiXml to parse a response from a 3rd party API. Due to some peculiarities of the response XML, this gem is forced to use the Ox backend. The client using this gem also has other dependencies which use MultiXml, though I'm not sure which back-end they prefer. Given that different backends result in different parsing behavior (see #30), I foresee disaster if I force all dependencies to use Ox (or if one of the dependencies forces my gem to use a backend other than Ox).
The naive solution would be to wrap calls to MultiXml.parse in my gem like so
Unfortunately, this won't work for me, because the client application is running in a multithreaded environment (Rails with Puma) and this approach is not thread-safe.
What I need is a thread safe way to tell my gem to use Ox when parsing without affecting other gems' usage of MultiXml.
One solution would be to add a :parser option to MultiXml.parse, which would override the globally configured parser for that particular case. Usage could look like
MutliXml.parse(xml,parser: :ox)
That is just a suggested solution, I know there are other ways to solve this problem too.
The text was updated successfully, but these errors were encountered:
tcollier
pushed a commit
to tcollier/multi_xml
that referenced
this issue
Mar 24, 2016
Accept new :parser option in MultiXml.parse and use that value instead of
the globally configurated parser.
This allows different gems to use different parsing backends within the same
application.
Fixessferik#50
I've written a gem that is using MultiXml to parse a response from a 3rd party API. Due to some peculiarities of the response XML, this gem is forced to use the Ox backend. The client using this gem also has other dependencies which use MultiXml, though I'm not sure which back-end they prefer. Given that different backends result in different parsing behavior (see #30), I foresee disaster if I force all dependencies to use Ox (or if one of the dependencies forces my gem to use a backend other than Ox).
The naive solution would be to wrap calls to
MultiXml.parse
in my gem like soUnfortunately, this won't work for me, because the client application is running in a multithreaded environment (Rails with Puma) and this approach is not thread-safe.
What I need is a thread safe way to tell my gem to use Ox when parsing without affecting other gems' usage of MultiXml.
One solution would be to add a
:parser
option toMultiXml.parse
, which would override the globally configured parser for that particular case. Usage could look likeThat is just a suggested solution, I know there are other ways to solve this problem too.
The text was updated successfully, but these errors were encountered: