X-Git-Url: https://scm.cri.ensmp.fr/git/Faustine.git/blobdiff_plain/c7f552fd8888da2f0d8cfb228fe0f28d3df3a12c..b4b6f2ea75b9f0f3ca918f5b84016610bf7a4d4f:/interpretor/preprocessor/faust-0.9.47mr3/compiler/signals/prim2.cpp diff --git a/interpretor/preprocessor/faust-0.9.47mr3/compiler/signals/prim2.cpp b/interpretor/preprocessor/faust-0.9.47mr3/compiler/signals/prim2.cpp new file mode 100644 index 0000000..f85d7c2 --- /dev/null +++ b/interpretor/preprocessor/faust-0.9.47mr3/compiler/signals/prim2.cpp @@ -0,0 +1,72 @@ +/************************************************************************ + ************************************************************************ + FAUST compiler + Copyright (C) 2003-2004 GRAME, Centre National de Creation Musicale + --------------------------------------------------------------------- + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program 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. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + ************************************************************************ + ************************************************************************/ + + + +#include "prim2.hh" +#include "stdlib.h" + +Sym FFUN = symbol ("ForeignFunction"); + +Tree ffunction (Tree signature, Tree incfile, Tree libfile) +{ + return tree(FFUN, signature, incfile, libfile); +} + +bool isffunction(Tree t) +{ + return t->node() == Node(FFUN); +} + +Tree ffsignature(Tree ff) +{ + return ff->branch(0); +} + +const char* ffincfile(Tree ff) +{ + return tree2str(ff->branch(1)); +} + +const char* fflibfile(Tree ff) +{ + return tree2str(ff->branch(2)); +} + +int ffrestype(Tree t) +{ + return tree2int(hd(ffsignature(t))); +} + +const char* ffname(Tree t) +{ + return tree2str(nth(ffsignature(t),1)); +} + +int ffarity(Tree t) +{ + return len(ffsignature(t))-2; +} + +int ffargtype(Tree t, int i) +{ + return tree2int(nth(ffsignature(t), i+2)); +}