mirror of
https://github.com/facebook/sapling.git
synced 2024-10-10 08:47:12 +03:00
50d6b599f4
These don't really have any dependencies on remotefilelog, so let's move them out.
80 lines
2.0 KiB
C++
80 lines
2.0 KiB
C++
// pythonutil.h - utilities to glue C++ code to python
|
|
//
|
|
// Copyright 2016 Facebook, Inc.
|
|
//
|
|
// This software may be used and distributed according to the terms of the
|
|
// GNU General Public License version 2 or any later version.
|
|
//
|
|
// no-check-code
|
|
|
|
#ifndef REMOTEFILELOG_PYTHONOBJ_H
|
|
#define REMOTEFILELOG_PYTHONOBJ_H
|
|
|
|
// The PY_SSIZE_T_CLEAN define must be defined before the Python.h include,
|
|
// as per the documentation.
|
|
#define PY_SSIZE_T_CLEAN
|
|
|
|
#include <Python.h>
|
|
#include <exception>
|
|
|
|
// Py_BuildValue treats NULL as NONE, so we have to have a non-null pointer.
|
|
#define MAGIC_EMPTY_STRING ""
|
|
|
|
/**
|
|
* C++ exception that represents an issue at the python C api level.
|
|
* When this is thrown, it's assumed that the python error message has been set
|
|
* and that the catcher of the exception should just return an error code value
|
|
* to the python API.
|
|
*/
|
|
class pyexception : public std::exception {
|
|
public:
|
|
pyexception() {
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Wrapper class for PyObject pointers.
|
|
* It is responsible for managing the Py_INCREF and Py_DECREF calls.
|
|
*/
|
|
class PythonObj {
|
|
private:
|
|
PyObject *obj;
|
|
|
|
public:
|
|
PythonObj();
|
|
|
|
PythonObj(PyObject *obj);
|
|
|
|
PythonObj(const PythonObj& other);
|
|
|
|
~PythonObj();
|
|
|
|
PythonObj& operator=(const PythonObj &other);
|
|
|
|
operator PyObject* () const;
|
|
|
|
/**
|
|
* Function used to obtain a return value that will persist beyond the life
|
|
* of the PythonObj. This is useful for returning objects to Python C apis
|
|
* and letting them manage the remaining lifetime of the object.
|
|
*/
|
|
PyObject *returnval();
|
|
|
|
/**
|
|
* Invokes getattr to retrieve the attribute from the python object.
|
|
*/
|
|
PythonObj getattr(const char *name);
|
|
|
|
/**
|
|
* Executes the current callable object if it's callable.
|
|
*/
|
|
PythonObj call(const PythonObj &args);
|
|
|
|
/**
|
|
* Invokes the specified method on this instance.
|
|
*/
|
|
PythonObj callmethod(const char *name, const PythonObj &args);
|
|
};
|
|
|
|
#endif //REMOTEFILELOG_PYTHONOBJ_H
|