255 lines
7.7 KiB
C
255 lines
7.7 KiB
C
/*
|
|
* Copyright (C) 2020 Weber Yann
|
|
*
|
|
* This file is part of pyrpn.
|
|
*
|
|
* pyrpn 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 3 of the License, or
|
|
* any later version.
|
|
*
|
|
* pyrpn 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 pyrpn. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#ifndef _PYTHON_IF_H__
|
|
#define _PYTHON_IF_H__
|
|
|
|
#include "config.h"
|
|
|
|
#include <errno.h>
|
|
|
|
#define PY_SSIZE_T_CLEAN
|
|
#include <Python.h>
|
|
#include "structmember.h"
|
|
|
|
#include "rpn_if.h"
|
|
#include "rpn_if_default.h"
|
|
#include "python_rpnexpr.h"
|
|
#include "python_const.h"
|
|
|
|
/**@file python_if.h
|
|
* @brief Python RPNIterExpr type headers
|
|
* @ingroup python_ext
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*
|
|
* This file is the header of the RPNIterExpr Python class
|
|
*/
|
|
|
|
/**@defgroup pymod_pyrpn_RPNExprIter class pyrpn.RPNExprIter
|
|
* @ingroup pymod_pyrpn
|
|
* @brief Exposed Python class : RPNIterExpr
|
|
*
|
|
* Iterated expression are composed of RPN expressions, they are able to
|
|
* iterate taking their parameters from a memory array and setting back values
|
|
* in it on each iteration.
|
|
*
|
|
* @see ifs_if
|
|
*/
|
|
|
|
/**@brief RPNIterExpr Python class type definition
|
|
* @ingroup pymod_pyrpn_RPNExprIter */
|
|
extern PyTypeObject RPNIterExprType;
|
|
|
|
/**@brief Structure holding RPNIterExpr objects
|
|
* @ingroup pymod_pyrpn_RPNExprIter */
|
|
typedef struct
|
|
{
|
|
/** Python's type definition */
|
|
PyObject_VAR_HEAD;
|
|
|
|
/** @brief Number of dimention in map */
|
|
size_t ndim;
|
|
|
|
/**@brief Pointer on @ref rpn_if_s */
|
|
rpn_if_t *rif;
|
|
|
|
/**@brief Python tuple with instances of RPNExpr */
|
|
PyObject *expr;
|
|
|
|
} PyRPNIterExpr_t;
|
|
|
|
/**@brief RpnIterExpr __new__ method
|
|
* @param subtype Type of object being created (pyrpn.RPNIterExpr)
|
|
* @param args positional arguments for subtype
|
|
* @param kwds keyword argumenrs for subtype
|
|
* @return The new Python RPNIterExpr object
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject* rpnif_new(PyTypeObject *subtype, PyObject* args, PyObject* kwds);
|
|
|
|
/**@brief RpnIterExpr constructor
|
|
* @param self New RPNIterExpr instance
|
|
* @param args Positional arguments list
|
|
* @param kwds Keywords arguments dict
|
|
* @return 0 if no error else -1
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
int rpnif_init(PyObject *self, PyObject *args, PyObject *kwds);
|
|
|
|
/**@brief RPNIterExpr __del__ method
|
|
* @param self RPNExpr instance
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
void rpnif_del(PyObject *self);
|
|
|
|
/**@brief Buffer protocol request handler method
|
|
* @param self RPNIterExpr instance
|
|
* @param view A memoryview to fill depending on flags
|
|
* @param flags Indicates the request type
|
|
* @return -1 on error
|
|
* See python documentation at
|
|
* https://docs.python.org/3/c-api/buffer.html#buffer-request-types
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
int rpnif_getbuffer(PyObject *self, Py_buffer *view, int flags);
|
|
|
|
/**@brief Buffer protocol request release method
|
|
* @param self RPNIterExppr instance
|
|
* @param view The memoryview to release (free what we filled)
|
|
* See python documentation at
|
|
* https://docs.python.org/3/c-api/buffer.html#buffer-request-types
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
void rpnif_releasebuffer(PyObject *self, Py_buffer *view);
|
|
|
|
/**@brief Return a named tuple of custom rif data
|
|
* @param self RPNIterExpr instance
|
|
* @return A RPNIterParams named tuple
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject *rpnif_get_params(PyObject *self);
|
|
|
|
/**@brief Return a tuple with data buffer's shape
|
|
* @param self RPNIterExpr instance
|
|
* @return A new ref on a tuple
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject *rpnif_shape(PyObject *self);
|
|
|
|
/**@brief Runs an IF on given position
|
|
* @param self RPNInterExpr instance
|
|
* @param pos The start position
|
|
* @return A new position
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject *rpnif_step(PyObject *self, PyObject* pos);
|
|
|
|
/**@brief Convert given arguments coordinates to position
|
|
* @param self RPNIterExpr instance
|
|
* @param argv Pointer on the array of arguments
|
|
* @param argc Argument count
|
|
* @return An integer
|
|
*/
|
|
PyObject *rpnif_to_pos(PyObject *self, PyObject** argv, Py_ssize_t argc);
|
|
|
|
/**@brief Convert given position to coordinates tuple
|
|
* @param self RPNIterExpr instance
|
|
* @param pos Position, as integer, to convert
|
|
* @return A tuple
|
|
*/
|
|
PyObject *rpnif_from_pos(PyObject *self, PyObject* pos);
|
|
|
|
/**@brief RPNIterExpr __getstate__ method for pickling
|
|
* @param cls RPNIterExpr type object
|
|
* @param noargs Not an argument...
|
|
* @return A bytes Python instance suitable as argument for
|
|
* @ref rpnexpr_setstate
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject* rpnif_getstate(PyObject *cls, PyObject *noargs);
|
|
|
|
/**@brief RPNIterExpr __setstate__ method for pickling
|
|
* @param cls RPNIterExpr type object
|
|
* @param state Should by a bytes Python instance returned by @ref
|
|
* rpnexpr_getstate
|
|
* @return A bytes Python instance suitable as argument for
|
|
* @ref rpnexpr_setstate
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject* rpnif_setstate(PyObject *cls, PyObject *state);
|
|
|
|
/**@brief RPNIterExpr.__repr__()
|
|
* @param self RPNIterExpr instance
|
|
* @return A string representation of the instance
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject* rpnif_repr(PyObject *self);
|
|
|
|
/**@brief RPNIterExpr.__str__()
|
|
* @param self RPNIterExpr instance
|
|
* @return A string representation of the instance
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject* rpnif_str(PyObject *self);
|
|
|
|
/**@brief RPNExpr.__len__() method
|
|
* @param self RPNIterExpr instance
|
|
* @return A integer with the number of tokens in expression
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
Py_ssize_t rpnif_len(PyObject *self);
|
|
|
|
/**@brief Sequence method for __getitem__ method
|
|
*
|
|
* Allow expressions access with integer indexes
|
|
* @param self RPNIterExpr instance
|
|
* @param idx Item index
|
|
* @return Corresponding RPNExpr or raise IndexError
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject* rpnif_expr_item(PyObject *self, Py_ssize_t idx);
|
|
|
|
/**@brief Sequence method for __setitem__ method
|
|
*
|
|
* Allow to recompile an expressions using a str with integer indexes
|
|
* @param self RPNIterExpr instance
|
|
* @param idx Item index
|
|
* @param elt The code (str) to compile in indicated expression
|
|
* @return 0 if no error else -1
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
int rpnif_expr_ass_item(PyObject *self, Py_ssize_t idx, PyObject* elt);
|
|
|
|
/**@brief Mapping method to access expressions by name
|
|
* @param self RPNIterExpr instance
|
|
* @param key An expression name (depending on parameters)
|
|
* @return The corresponding RPNExpr of raise KeyError
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
PyObject* rpnif_subscript(PyObject *self, PyObject *key);
|
|
|
|
/**@brief Mapping method to recompile an expression by name
|
|
* @param self RPNIterExpr instance
|
|
* @param key An expression name (depending on parameters)
|
|
* @param elt The code (str) to compile in indicated expression
|
|
* @return 0 if no error else -1
|
|
* @ingroup pymod_pyrpn_RPNExprIter
|
|
*/
|
|
int rpnif_ass_subscript(PyObject *self, PyObject *key, PyObject *elt);
|
|
|
|
/**@brief Mimics dict.keys() method
|
|
* @param self RPNIterExpr instance
|
|
* @return A tuple with expressions name
|
|
* @ingroup pymod_pyrpn_RPNExprIter */
|
|
PyObject *rpnif_keys(PyObject *self);
|
|
|
|
/**@brief Mimics dict.values() method
|
|
* @param self RPNIterExpr instance
|
|
* @return A tuple with RPNExpr instances
|
|
* @ingroup pymod_pyrpn_RPNExprIter */
|
|
PyObject *rpnif_values(PyObject *self);
|
|
|
|
/**@brief Mimics dict.items() method
|
|
* @param self RPNIterExpr instance
|
|
* @return A tuple with tuples(key, value)
|
|
* @ingroup pymod_pyrpn_RPNExprIter */
|
|
PyObject *rpnif_items(PyObject *self);
|
|
|
|
|
|
#endif
|
|
|