1 /************************************************************************ 2 ************************************************************************ 3 FAUST compiler 4 Copyright (C) 2003-2018 GRAME, Centre National de Creation Musicale 5 --------------------------------------------------------------------- 6 This program is free software; you can redistribute it and/or modify 7 it under the terms of the GNU General Public License as published by 8 the Free Software Foundation; either version 2 of the License, or 9 (at your option) any later version. 10 11 This program is distributed in the hope that it will be useful, 12 but WITHOUT ANY WARRANTY; without even the implied warranty of 13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 GNU General Public License for more details. 15 16 You should have received a copy of the GNU General Public License 17 along with this program; if not, write to the Free Software 18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 19 ************************************************************************ 20 ************************************************************************/ 21 22 #ifndef _FAUSTFLOATS_ 23 #define _FAUSTFLOATS_ 24 25 #include <iostream> 26 #include <float.h> 27 28 #include "instructions.hh" 29 30 #define FLOATMACRO "FAUSTFLOAT" 31 #define FLOATMACROPTR "FAUSTFLOAT*" 32 #define FLOATMACROPTRPTR "FAUSTFLOAT**" 33 #define FLOATCASTER "(" FLOATMACRO ")" 34 35 const char* isuffix(); 36 const char* inumix(); 37 double inummin(); 38 39 int ifloatsize(); 40 const char* ifloat(); 41 const char* ifloatptr(); 42 const char* ifloatptrptr(); 43 Typed::VarType itfloat(); 44 Typed::VarType itfloatptr(); 45 Typed::VarType itfloatptrptr(); 46 const char* icast(); 47 48 const char* xfloat(); 49 const char* xcast(); 50 51 void initFaustFloat(); 52 53 void printfloatdef(std::ostream& fout); 54 55 typedef long double quad; 56 57 #endif 58