/* -*- mode: C -*- */
/*
IGraph library.
Copyright (C) 2006 Gabor Csardi <csardi@rmki.kfki.hu>
MTA RMKI, Konkoly-Thege Miklos st. 29-33, Budapest 1121, Hungary
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA
*/
#include "common.h"
#include "structmember.h"
/**
* \ingroup python_interface
* \brief Handler function for all unimplemented \c igraph.Graph methods
*
* This function is called whenever an unimplemented \c igraph.Graph method
* is called ("unimplemented" meaning that there is a method name in the
* method table of \c igraph.Graph , but there isn't any working implementation
* either because the underlying \c igraph API might be subject to change
* or because the calling format from Python is not decided yet (or maybe
* because of laziness or lack of time ;))
*
* All of the parameters are ignored, they are here just to make the
* function satisfy the requirements of \c PyCFunction, thus allowing it
* to be included in a method table.
*
* \return NULL
*/
PyObject* igraphmodule_unimplemented(PyObject* self, PyObject* args, PyObject* kwds)
{
PyErr_SetString(PyExc_NotImplementedError, "This method is unimplemented.");
return NULL;
}
/**
* \ingroup python_interface
* \brief Resolves a weak reference to an \c igraph.Graph
* \return the \c igraph.Graph object or NULL if the weak reference is dead.
* Sets an exception in the latter case.
*/
PyObject* igraphmodule_resolve_graph_weakref(PyObject* ref) {
PyObject *o;
if (!PyWeakref_Check(ref)) {
PyErr_SetString(PyExc_TypeError, "weak reference expected");
return NULL;
}
o=PyWeakref_GetObject(ref);
if (o == Py_None) {
PyErr_SetString(PyExc_TypeError, "underlying graph has already been destroyed");
return NULL;
}
return o;
}
syntax highlighted by Code2HTML, v. 0.9.1