[C++-sig] Embedding...
Stefan Seefeld
seefeld at sympatico.ca
Mon Oct 23 21:35:29 CEST 2006
Beau Sapach wrote:
> Hello Everyone,
>
>
> I'm looking to embed Python in an application I'm working on in C++. I've
> been trying out Boost.Python and it seems pretty straight forward but
> doesn't have (that I've found yet anyway) any complete examples to follow
> for embedding Python. What I want to be able to do is give users access to
> objects created in C++ land inside a Python window within my .exe.
Have you looked at the code from CVS ? I added some support for embedding
sometime in 2005 (after the 1.33 release branch was created), containing
'exec', 'exec_string', and 'import' functions:
http://cci.lbl.gov/~rwgk/shortcuts/boost//libs/python/doc/v2/exec.html
(The docs at boost.org don't include these bits yet as they only document
the last release.)
> I'm assuming I'll have to create instances of my classes in C++, for example
> when my application is starting up. Then I would have to create a Python
> interpreter and have it call Python functions to give it references to my
> previously created C++ objects. Lastly, show the Python window to the user.
Right. One way is to have preexisting (C++) objects be bound to python
objects that get exposed to user scripts that are run from within the main
(C++) application by means of an embedded python interpreter.
> Please correct me if I'm wrong in how I'm imagining this... The problem I'm
> having right now is that Boost.Python seems very good for creating DLLs to
> give Python access to classes and functions, but how do I make
> classes/functions that are compiled as part of my exe available to python
> WITHIN the same exe???
See above. The bits to actually provide the missing link are straight forward,
so you may put it into your own code, if you can't use the latest not-quite-released-yet
version of boost:
// Execute python source code from file filename.
// global and local are the global and local scopes respectively,
// used during execution.
object exec_file(str filename, object global, object local)
{
// should be 'char const *' but older python versions don't use 'const' yet.
char *f = python::extract<char *>(filename);
// Let python open the file to avoid potential binary incompatibilities.
PyObject *pyfile = PyFile_FromString(f, "r");
if (!pyfile) throw std::invalid_argument(std::string(f) + " : no such file");
python::handle<> file(pyfile);
PyObject* result = PyRun_File(PyFile_AsFile(file.get()),
f,
Py_file_input,
global.ptr(), local.ptr());
if (!result) throw_error_already_set();
return object(detail::new_reference(result));
}
Good luck,
Stefan
--
...ich hab' noch einen Koffer in Berlin...
More information about the Cplusplus-sig
mailing list