Norimasa Okamoto
/
pymite
python-on-a-chip online compiler
- http://pymbed.appspot.com/
- https://code.google.com/p/python-on-a-chip/
- http://www.youtube.com/watch?v=Oyqc2bFRW9I
- https://bitbucket.org/va009039/pymbed/
more info: python-on-a-chip
vm/float.h
- Committer:
- va009039
- Date:
- 2016-04-14
- Revision:
- 15:94ca5c8003e5
- Parent:
- 0:65f1469d6bfb
File content as of revision 15:94ca5c8003e5:
/* # This file is Copyright 2009 Dean Hall. # This file is part of the PyMite VM. # This file is licensed under the MIT License. # See the LICENSE file for details. */ #ifndef __FLOAT_H__ #define __FLOAT_H__ /** * \file * \brief Float Object Type * * Float object type header. */ /** * Float obj * * 32b floating point number */ typedef struct PmFloat_s { /** Object descriptor */ PmObjDesc_t od; /** Float value */ float val; } PmFloat_t, *pPmFloat_t; #ifdef HAVE_FLOAT /** * Creates a new Float object * * @param f Value to assign float (signed 32-bit). * @param r_pint Return by ref, ptr to new float * @return Return status */ PmReturn_t float_new(float f, pPmObj_t *r_pf); /** * Implements the UNARY_NEGATIVE bcode. * * Creates a new float with a value that is the negative of the given float. * * @param pobj Pointer to target object * @param r_pint Return by ref, ptr to float * @return Return status */ PmReturn_t float_negative(pPmObj_t pf, pPmObj_t *r_pf); /** * Returns by reference a float that is x op y. * * @param px The float left-hand argument * @param py The float right-hand argument * @param r_pn The return value of x op y * @param op The operator (+,-,*,/ and power) * @return Return status */ PmReturn_t float_op(pPmObj_t px, pPmObj_t py, pPmObj_t *r_pn, int8_t op); /** * Returns by reference a boolean that is x op y. * * @param px The float left-hand argument * @param py The float right-hand argument * @param r_pn The return value of x cmp y * @param cmp The comparison operator * @return Return status */ PmReturn_t float_compare(pPmObj_t px, pPmObj_t py, pPmObj_t *r_pobj, PmCompare_t cmp); #ifdef HAVE_PRINT /** * Sends out a float object. * The number is preceded with a "-" when necessary. * * @param pObj Ptr to float object * @return Return status */ PmReturn_t float_print(pPmObj_t pf); #endif /* HAVE_PRINT */ #endif /* HAVE_FLOAT */ #endif /* __FLOAT_H__ */