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

130 lines
3.2 KiB
C

/*
# This file is Copyright 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 __CLASS_H__
#define __CLASS_H__
/**
* \file
* \brief Class header.
*/
/**
* Class struct
*
* This C struct is used for PyMite class objects
* Note: Exceptions are objects.
*/
typedef struct PmClass_s
{
/** Object descriptor */
PmObjDesc_t od;
/** Attributes dict */
pPmDict_t cl_attrs;
/** Bases tuple */
pPmTuple_t cl_bases;
} PmClass_t,
*pPmClass_t;
/** Class instance struct */
typedef struct PmInstance_s
{
/** Object descriptor */
PmObjDesc_t od;
/** Class of this instance */
pPmClass_t cli_class;
/** Attributes dict */
pPmDict_t cli_attrs;
} PmInstance_t,
*pPmInstance_t;
/** Method struct */
typedef struct PmMethod_s
{
/** Object descriptor */
PmObjDesc_t od;
/** Class instance of this method */
pPmInstance_t m_instance;
/** Func of this method */
pPmFunc_t m_func;
/** Attributes dict */
pPmDict_t m_attrs;
} PmMethod_t,
*pPmMethod_t;
/**
* Creates a new Class object from the methods dict, bases tuple,
* and name string.
*
* @param pmeths ptr to methods dict.
* @param pbases ptr to bases tuple.
* @param pname ptr to name string.
* @param r_pclass Return by ref, ptr to new class
* @return Return status
*/
PmReturn_t class_new(pPmObj_t pmeths, pPmObj_t pbases, pPmObj_t pname,
pPmObj_t *r_pclass);
/**
* Returns an instance of the given class
*
* @param pclass Pointer to class object
* @param r_pobj Return by ref, instance object
* @return Return status
*/
PmReturn_t class_instantiate(pPmObj_t pclass, pPmObj_t *r_pobj);
/**
* Returns a method based on the given inputs
*
* @param pinstance ptr to instance
* @param pfunc ptr to func
* @param r_pmeth Return by ref, ptr to new method
* @return Return status
*/
PmReturn_t class_method(pPmObj_t pinstance, pPmObj_t pfunc, pPmObj_t *r_pmeth);
/**
* Returns the first attribute named __init__ in the class' inheritance tree
*
* @param pobj ptr to class or instance to search
* @param pname ptr to name of attr to find
* @param r_pobj Return by ref, ptr to attr if found, or undetermined
* @return Return status
*/
PmReturn_t class_getAttr(pPmObj_t pobj, pPmObj_t pname, pPmObj_t *r_pobj);
/**
* Returns a C boolean if the base class is found in the inheritance tree
* of the test class. NOTE: This function is recursive.
*
* @param ptest_class ptr to class whose inheritance tree is searched
* @param pbase_class ptr to class to look for
* @return Returns C_TRUE if pbase_class is found in the inheritance tree;
* C_FALSE otherwise.
*/
uint8_t class_isSubclass(pPmObj_t ptest_class, pPmObj_t pbase_class);
#endif /* __CLASS_H__ */