mirror of
https://github.com/triqs/dft_tools
synced 2025-01-12 14:08:24 +01:00
f1c32012a6
- for all functions, except when GIL option (not implemented) is here we use a triqs::py_stream, which redirect the stream to python sys.write - so that a simple C++ code with a std::cout print its output in the notebook... - NB : it only works for the code within the cell. If it calls another function on the lib which uses cout, print is not redirected. Designed for simple tests.... - cerr not (yet) redirected. (useful ?).
63 lines
1.6 KiB
C++
63 lines
1.6 KiB
C++
#pragma once
|
|
#include <Python.h>
|
|
|
|
namespace triqs {
|
|
namespace py_tools {
|
|
|
|
//--------------------- pyref -----------------------------
|
|
|
|
// a little class to hold an owned ref, make sure it is decref at destruction
|
|
class pyref {
|
|
PyObject *ob = NULL;
|
|
|
|
public:
|
|
pyref() = default;
|
|
pyref(PyObject *new_ref) : ob(new_ref) {}
|
|
~pyref() { Py_XDECREF(ob); }
|
|
operator PyObject *() const { return ob; }
|
|
PyObject *new_ref() const {
|
|
Py_XINCREF(ob);
|
|
return ob;
|
|
}
|
|
explicit operator bool() const { return (ob != NULL); }
|
|
bool is_null() const { return ob == NULL; }
|
|
bool is_None() const { return ob == Py_None; }
|
|
|
|
pyref attr(const char *s) {
|
|
return (ob ? PyObject_GetAttrString(ob, s) : NULL);
|
|
} // NULL : pass the error in chain call x.attr().attr()....
|
|
|
|
pyref operator()(PyObject *a1) {
|
|
return (ob ? PyObject_CallFunctionObjArgs(ob, a1, NULL) : NULL);
|
|
} // NULL : pass the error in chain call x.attr().attr()....
|
|
|
|
pyref operator()(PyObject *a1, PyObject *a2) {
|
|
return (ob ? PyObject_CallFunctionObjArgs(ob, a1, a2, NULL) : NULL);
|
|
} // NULL : pass the error in chain call x.attr().attr()....
|
|
|
|
pyref(pyref const &p) {
|
|
ob = p.ob;
|
|
Py_XINCREF(ob);
|
|
}
|
|
pyref(pyref &&p) {
|
|
ob = p.ob;
|
|
p.ob = NULL;
|
|
}
|
|
pyref &operator=(pyref const &) = delete;
|
|
pyref &operator=(pyref &&p) {
|
|
ob = p.ob;
|
|
p.ob = NULL;
|
|
return *this;
|
|
}
|
|
static pyref module(std::string const &module_name) { return PyImport_ImportModule(module_name.c_str()); }
|
|
static pyref string(std::string const &s) { return PyString_FromString(s.c_str()); }
|
|
};
|
|
|
|
inline pyref borrowed(PyObject *ob) {
|
|
Py_XINCREF(ob);
|
|
return {ob};
|
|
}
|
|
}
|
|
}
|
|
|