python-on-a-chip online compiler

Dependencies:   mbed TSI

/media/uploads/va009039/p14p-f446re.png

more info: python-on-a-chip

Committer:
va009039
Date:
Sat Mar 02 11:54:20 2013 +0000
Revision:
0:65f1469d6bfb
first commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
va009039 0:65f1469d6bfb 1 /*
va009039 0:65f1469d6bfb 2 # This file is Copyright 2009 Dean Hall.
va009039 0:65f1469d6bfb 3 # This file is part of the PyMite VM.
va009039 0:65f1469d6bfb 4 # This file is licensed under the MIT License.
va009039 0:65f1469d6bfb 5 # See the LICENSE file for details.
va009039 0:65f1469d6bfb 6 */
va009039 0:65f1469d6bfb 7
va009039 0:65f1469d6bfb 8
va009039 0:65f1469d6bfb 9 #ifndef __CLASS_H__
va009039 0:65f1469d6bfb 10 #define __CLASS_H__
va009039 0:65f1469d6bfb 11
va009039 0:65f1469d6bfb 12 /**
va009039 0:65f1469d6bfb 13 * \file
va009039 0:65f1469d6bfb 14 * \brief Class header.
va009039 0:65f1469d6bfb 15 */
va009039 0:65f1469d6bfb 16
va009039 0:65f1469d6bfb 17
va009039 0:65f1469d6bfb 18 /**
va009039 0:65f1469d6bfb 19 * Class struct
va009039 0:65f1469d6bfb 20 *
va009039 0:65f1469d6bfb 21 * This C struct is used for PyMite class objects
va009039 0:65f1469d6bfb 22 * Note: Exceptions are objects.
va009039 0:65f1469d6bfb 23 */
va009039 0:65f1469d6bfb 24 typedef struct PmClass_s
va009039 0:65f1469d6bfb 25 {
va009039 0:65f1469d6bfb 26 /** Object descriptor */
va009039 0:65f1469d6bfb 27 PmObjDesc_t od;
va009039 0:65f1469d6bfb 28
va009039 0:65f1469d6bfb 29 /** Attributes dict */
va009039 0:65f1469d6bfb 30 pPmDict_t cl_attrs;
va009039 0:65f1469d6bfb 31
va009039 0:65f1469d6bfb 32 /** Bases tuple */
va009039 0:65f1469d6bfb 33 pPmTuple_t cl_bases;
va009039 0:65f1469d6bfb 34 } PmClass_t,
va009039 0:65f1469d6bfb 35 *pPmClass_t;
va009039 0:65f1469d6bfb 36
va009039 0:65f1469d6bfb 37 /** Class instance struct */
va009039 0:65f1469d6bfb 38 typedef struct PmInstance_s
va009039 0:65f1469d6bfb 39 {
va009039 0:65f1469d6bfb 40 /** Object descriptor */
va009039 0:65f1469d6bfb 41 PmObjDesc_t od;
va009039 0:65f1469d6bfb 42
va009039 0:65f1469d6bfb 43 /** Class of this instance */
va009039 0:65f1469d6bfb 44 pPmClass_t cli_class;
va009039 0:65f1469d6bfb 45
va009039 0:65f1469d6bfb 46 /** Attributes dict */
va009039 0:65f1469d6bfb 47 pPmDict_t cli_attrs;
va009039 0:65f1469d6bfb 48 } PmInstance_t,
va009039 0:65f1469d6bfb 49 *pPmInstance_t;
va009039 0:65f1469d6bfb 50
va009039 0:65f1469d6bfb 51 /** Method struct */
va009039 0:65f1469d6bfb 52 typedef struct PmMethod_s
va009039 0:65f1469d6bfb 53 {
va009039 0:65f1469d6bfb 54 /** Object descriptor */
va009039 0:65f1469d6bfb 55 PmObjDesc_t od;
va009039 0:65f1469d6bfb 56
va009039 0:65f1469d6bfb 57 /** Class instance of this method */
va009039 0:65f1469d6bfb 58 pPmInstance_t m_instance;
va009039 0:65f1469d6bfb 59
va009039 0:65f1469d6bfb 60 /** Func of this method */
va009039 0:65f1469d6bfb 61 pPmFunc_t m_func;
va009039 0:65f1469d6bfb 62
va009039 0:65f1469d6bfb 63 /** Attributes dict */
va009039 0:65f1469d6bfb 64 pPmDict_t m_attrs;
va009039 0:65f1469d6bfb 65 } PmMethod_t,
va009039 0:65f1469d6bfb 66 *pPmMethod_t;
va009039 0:65f1469d6bfb 67
va009039 0:65f1469d6bfb 68
va009039 0:65f1469d6bfb 69 /**
va009039 0:65f1469d6bfb 70 * Creates a new Class object from the methods dict, bases tuple,
va009039 0:65f1469d6bfb 71 * and name string.
va009039 0:65f1469d6bfb 72 *
va009039 0:65f1469d6bfb 73 * @param pmeths ptr to methods dict.
va009039 0:65f1469d6bfb 74 * @param pbases ptr to bases tuple.
va009039 0:65f1469d6bfb 75 * @param pname ptr to name string.
va009039 0:65f1469d6bfb 76 * @param r_pclass Return by ref, ptr to new class
va009039 0:65f1469d6bfb 77 * @return Return status
va009039 0:65f1469d6bfb 78 */
va009039 0:65f1469d6bfb 79 PmReturn_t class_new(pPmObj_t pmeths, pPmObj_t pbases, pPmObj_t pname,
va009039 0:65f1469d6bfb 80 pPmObj_t *r_pclass);
va009039 0:65f1469d6bfb 81
va009039 0:65f1469d6bfb 82 /**
va009039 0:65f1469d6bfb 83 * Returns an instance of the given class
va009039 0:65f1469d6bfb 84 *
va009039 0:65f1469d6bfb 85 * @param pclass Pointer to class object
va009039 0:65f1469d6bfb 86 * @param r_pobj Return by ref, instance object
va009039 0:65f1469d6bfb 87 * @return Return status
va009039 0:65f1469d6bfb 88 */
va009039 0:65f1469d6bfb 89 PmReturn_t class_instantiate(pPmObj_t pclass, pPmObj_t *r_pobj);
va009039 0:65f1469d6bfb 90
va009039 0:65f1469d6bfb 91 #ifdef HAVE_AUTOBOX
va009039 0:65f1469d6bfb 92 /**
va009039 0:65f1469d6bfb 93 * Autoboxes an object in place
va009039 0:65f1469d6bfb 94 *
va009039 0:65f1469d6bfb 95 * @param pclass Pointer to object
va009039 0:65f1469d6bfb 96 * @return Return status
va009039 0:65f1469d6bfb 97 */
va009039 0:65f1469d6bfb 98 PmReturn_t class_autobox(pPmObj_t *pobj);
va009039 0:65f1469d6bfb 99 #endif
va009039 0:65f1469d6bfb 100
va009039 0:65f1469d6bfb 101 /**
va009039 0:65f1469d6bfb 102 * Returns a method based on the given inputs
va009039 0:65f1469d6bfb 103 *
va009039 0:65f1469d6bfb 104 * @param pinstance ptr to instance
va009039 0:65f1469d6bfb 105 * @param pfunc ptr to func
va009039 0:65f1469d6bfb 106 * @param r_pmeth Return by ref, ptr to new method
va009039 0:65f1469d6bfb 107 * @return Return status
va009039 0:65f1469d6bfb 108 */
va009039 0:65f1469d6bfb 109 PmReturn_t class_method(pPmObj_t pinstance, pPmObj_t pfunc, pPmObj_t *r_pmeth);
va009039 0:65f1469d6bfb 110
va009039 0:65f1469d6bfb 111 /**
va009039 0:65f1469d6bfb 112 * Returns the first attribute named __init__ in the class' inheritance tree
va009039 0:65f1469d6bfb 113 *
va009039 0:65f1469d6bfb 114 * @param pobj ptr to class or instance to search
va009039 0:65f1469d6bfb 115 * @param pname ptr to name of attr to find
va009039 0:65f1469d6bfb 116 * @param r_pobj Return by ref, ptr to attr if found, or undetermined
va009039 0:65f1469d6bfb 117 * @return Return status
va009039 0:65f1469d6bfb 118 */
va009039 0:65f1469d6bfb 119 PmReturn_t class_getAttr(pPmObj_t pobj, pPmObj_t pname, pPmObj_t *r_pobj);
va009039 0:65f1469d6bfb 120
va009039 0:65f1469d6bfb 121 /**
va009039 0:65f1469d6bfb 122 * Returns a C boolean if the base class is found in the inheritance tree
va009039 0:65f1469d6bfb 123 * of the test class. NOTE: This function is recursive.
va009039 0:65f1469d6bfb 124 *
va009039 0:65f1469d6bfb 125 * @param ptest_class ptr to class whose inheritance tree is searched
va009039 0:65f1469d6bfb 126 * @param pbase_class ptr to class to look for
va009039 0:65f1469d6bfb 127 * @return Returns C_TRUE if pbase_class is found in the inheritance tree;
va009039 0:65f1469d6bfb 128 * C_FALSE otherwise.
va009039 0:65f1469d6bfb 129 */
va009039 0:65f1469d6bfb 130 uint8_t class_isSubclass(pPmObj_t ptest_class, pPmObj_t pbase_class);
va009039 0:65f1469d6bfb 131
va009039 0:65f1469d6bfb 132 #endif /* __CLASS_H__ */