-
Notifications
You must be signed in to change notification settings - Fork 50
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make JCB in Job Status and Control interface an abstract type #208
Comments
Just a quick note on this. At least for my purposes, it would be fine for it to remain JSON so long as it ceases to expose the json_c type itself. Preferably handing out const handles to a JSON string, or similar. |
Thanks. Also a quick note. One of the reasons that I didn't want to use JSON strings as input/output was that this seemed to add high overheads. E.g., the JSC user will construct a JSON-C JCB blob and covert it to a JSON string to pass it to JSC, then JSC will reconstruct it to an JSON-C object to send to the KVS. A question. If I hide JSON-C under an abstract type and provide accessor functions as suggested by @garlick, does this work better or worse with Python binding? |
It would probably be slightly better in that I wouldn't have to convert it to a string, then interpret the string as json to convert it into a python data structure then go back through it the whole way on the other end. I'm not sure I entirely see the overhead point though. The KVS uses JSON strings internally, so once we have an interface for just directly passing them in I think much of the overhead you're considering would go away. Perhaps I'm not thinking of the specific problem case though. |
Thanks. I will think about this more when I revisit this issue and may pick your brain a bit at that time. Perhaps more importantly, how urgent is it to wrap the python binding to this more completely for your HT scheduling milestone -- don't want to drag your feet and will adjust my priority accordingly. |
Not that important. I made a wrapper class for handling json_object unpacking and conversion that makes it relatively straightforward to handle things like this. I more brought up the issue because we've been making a concerted effort, mainly @garlick really has, to excise library types from the interface, such as zmsg_t and json_object. It's more to allow the clients, in this case the python bindings, to use a native JSON library rather than having to deal with creating a json_c-specific object. Right now I do it like this: j = Jobj(
json.dumps(python_object)
) Which converts the python object into a JSON string with a native library then has json_c interpret it and create a json_object to pass. This is really, really inefficient. Using any other json library would entail a similar issue as long as it's in the API. |
Right: |
Is this issue resolved now? Handled via 92169c5? |
Yeah, I'm good with that as solved. Thanks for the triage. |
As discussed in PR #205
The text was updated successfully, but these errors were encountered: