-
Notifications
You must be signed in to change notification settings - Fork 26
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
Support multiple interpreter instance? #302
Comments
We have thought about that and initially this was part of the design. However, this makes the interfaces quite ugly and we moved away from that approach. Perhaps, we could have some list of interpreters and we could change the "active" interpreter. Would that work for your use case? |
That could be a solution as well. At least, we need a |
I agree... Do you have an implementation in mind? |
I suspect we want to replace the static interpreter instance with an user-provided callback or something like that where the user is responsible for maintaining the top of the interpreter stack? |
No. I'm still experimenting with the library. I'm wondering how cppyy solves this problem. Another way is to expose a C wrapper over the internal CppInterOp Interpreter, so users can manage those instances on their own. We only need to maintain a stable C API. The The following C++ APIs are just helper functions or wrappers over
However, these two APIs are not trivial to reimplement.
I think we could do what CppInterOp/lib/Interpreter/CppInterOp.cpp Line 2353 in 6a5f564
In this way, the C++ interfaces can be kept concise and clean. The new C interfaces are born to be ugly. :) |
Cppyy is not know to have good interfaces to communicate with the underlying infrastructure. It wraps them into multiple layers via the CPyCppyy and the cling-backend. Let's ping @wlav for a better take on this.
Yes, right now CppInterOp is not in a good place in that respect. The intent has been that these interfaces to be C compatible and to not change a lot. However, it is really challenging to provide C-compatible interfaces when we deal with collections (
I think it is really better to provide a C interface. That's why we will be safe.
I agree. Once you are beyond the experimental part of this we can discuss about what are the needs. One thing I'd like to point out is that in an ideal world a lot of this code will land in |
Preface with a note that the multi-interpreter case is a common one, especially if they could be spun up quickly, or "forked" from the state of a parent interpreter. The latter would be awesome for writing C++ unit tests.
Well, it worked for 3 applications so far. :) CPyCppyy, PyPy/_cppyy, and the D language bindings. There have been a few others that I'm aware of, e.g. an NLP application, but AFAIK, these were one-offs grad student projects. Just that I have misgivings about it b/c it's been grown organically and even as that hasn't limited functionality, there are several inefficiencies that I don't think are necessary.
No, CPyCppyy isn't part of it. The layerings are clingwrapper and ROOT/meta. For the former, the above message applies, the latter, well ... :}
Right, that's how clingwrapper started as well: to bootstrap C++ bindings into PyPy, we had to start with C bindings and that's where several of the inefficiencies stem from. Eg., as you say, it's hard to share a container with C (esp. since the C binding in PyPy is ABI-based), so that's in the current implementation, there are several places where it loops with an
I did the same later: re-implemented the C interfaces on top of the C++ ones. However, it's still mostly 1-to-1, the C wrappers taking care of some amount of memory handling. |
This issue is stale because it has been open for 90 days with no activity. |
This issue was closed because it has been inactive for 14 days since being marked as stale. |
You know, being able to have multiple interpreters and in particular being able to start/run/discard would be a killer feature and if the cleanup/ClangREPL is what enables it by removing all the ROOT/meta crud, it'd be a major reason to move. Maybe reconsider that "not planned"? |
That's the annoying bot that comes after us if something is stale... |
@vgvassilev if you want the bot to ignore this issue then we can add a to-fix label |
The principle is sound:
So that in theory at least should allow me to have different C++ project be bound within their own interpreter, each with their own PCH, no? |
Sure. We can create a stack of interpreters and you can work with by changing the active one. Do you have a minimal motivating example that we can start from? |
Making a stack may not work; at least as-is, the callbacks would be mighty confused. I was planning to compartmentalize completely all JITing tasks in clingwrapper, by tracking a handle on the Python side (you can't bootstrap this; above, I'm working through the C API). A good example to start would be to have 2 independent Python modules, each with their own interpreter, for |
CppInterOp/lib/Interpreter/CppInterOp.cpp
Lines 58 to 73 in ecbffaf
The interpreter is global and unique at the moment. However, clients do not always agree on the same compiler configuration. I think we need to add more APIs that take
compat::Interpreter
as argument. For example,The text was updated successfully, but these errors were encountered: