1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-22 07:52:12 +01:00

176 lines
4.5 KiB
C

/*
# This file is Copyright 2003, 2006, 2007, 2009, 2010 Dean Hall.
#
# This file is part of the PyMite VM.
# The PyMite VM is free software: you can redistribute it and/or modify
# it under the terms of the GNU GENERAL PUBLIC LICENSE Version 2.
#
# The PyMite VM 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.
# A copy of the GNU GENERAL PUBLIC LICENSE Version 2
# is seen in the file COPYING in this directory.
*/
#ifndef __LIST_H__
#define __LIST_H__
/**
* \file
* \brief List Object Type
*
* List object type header.
*/
/**
* List obj
*
* Mutable ordered sequence of objects. Contains ptr to linked list of nodes.
*/
typedef struct PmList_s
{
/** Object descriptor */
PmObjDesc_t od;
/** List length; number of objs linked */
int16_t length;
/** Ptr to linked list of nodes */
pSeglist_t val;
} PmList_t,
*pPmList_t;
/**
* Allocates a new List object.
*
* If there is not enough memory to allocate the List,
* the return status will indicate an OutOfMemoryError
* that must be passed up to the interpreter.
* Otherwise, a ptr to the list is returned by reference
* and the return status is OK.
*
* @param r_pobj Return; addr of ptr to obj
* @return Return status
*/
PmReturn_t list_new(pPmObj_t *r_pobj);
/**
* Gets the object in the list at the index.
*
* @param plist Ptr to list obj
* @param index Index into list
* @param r_pobj Return by reference; ptr to item
* @return Return status
*/
PmReturn_t list_getItem(pPmObj_t plist, int16_t index, pPmObj_t *r_pobj);
/**
* Sets the item in the list at the index.
*
* @param plist Ptr to list
* @param index Index into list
* @param pobj Ptr to obj to put into list
* @return Return status
*/
PmReturn_t list_setItem(pPmObj_t plist, int16_t index, pPmObj_t pobj);
/**
* Makes a copy of the given list.
*
* Allocate the necessary memory for root and nodes.
* Duplicate ptrs to objs.
*
* @param pobj Ptr to source list
* @param r_pobj Return; Addr of ptr to return obj
* @return Return status
*/
PmReturn_t list_copy(pPmObj_t pobj, pPmObj_t *r_pobj);
/**
* Appends the given obj to the end of the given list.
*
* Allocate the memory for the node.
* Do not copy obj, just reuse ptr.
*
* @param plist Ptr to list
* @param pobj Ptr to item to append
* @return Return status
*/
PmReturn_t list_append(pPmObj_t plist, pPmObj_t pobj);
/**
* Creates a new list with the contents of psrclist
* copied pint number of times.
* This implements the python code "[0,...] * N"
* where the list can be any list and N is an integer.
*
* @param psrclist The source list to replicate
* @param n The integer number of times to replicate it
* @param r_pnewlist Return; new list with its contents set.
* @return Return status
*/
PmReturn_t list_replicate(pPmObj_t psrclist, int16_t n, pPmObj_t *r_pnewlist);
/**
* Inserts the object into the list at the desired index.
*
* @param plist Ptr to list obj
* @param pobj Ptr to obj to insert
* @param index Index of where to insert obj
* @return Return status
*/
PmReturn_t list_insert(pPmObj_t plist, int16_t index, pPmObj_t pobj);
/**
* Removes a given object from the list.
*
* @param plist Ptr to list obj
* @param item Ptr to object to be removed
* @return Return status
*/
PmReturn_t list_remove(pPmObj_t plist, pPmObj_t item);
/**
* Finds the first index of the item that matches pitem.
* Returns an ValueError Exception if the item is not found.
*
* @param plist Ptr to list obj
* @param pitem Ptr to object to be removed
* @param r_index Return by reference; ptr to index (C uint16)
* @return Return status
*/
PmReturn_t list_index(pPmObj_t plist, pPmObj_t pitem, uint16_t *r_index);
/**
* Removes the item at the given index.
* Raises a TypeError if the first argument is not a list.
* Raises an IndexError if the index is out of bounds.
*
* @param plist Ptr to list obj
* @param index Index of item to remove
* @return Return status
*/
PmReturn_t list_delItem(pPmObj_t plist, int16_t index);
#ifdef HAVE_PRINT
/**
* Prints out a list. Uses obj_print() to print elements.
*
* @param pobj Object to print.
* @return Return status
*/
PmReturn_t list_print(pPmObj_t pobj);
#endif /* HAVE_PRINT */
/**
* Removes all items from the list and zeroes the length.
*
* @param plist List to clear
* @return Return status
*/
PmReturn_t list_clear(pPmObj_t plist);
#endif /* __LIST_H__ */