Merge branch 'OOP' of https://scm.cri.ensmp.fr/git/Faustine into OOP
[Faustine.git] / interpretor / faust-0.9.47mr3 / compiler / generator / compile_sched.hh
1 /************************************************************************
2 ************************************************************************
3 FAUST compiler
4 Copyright (C) 2003-2004 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
23
24 #ifndef _COMPILE_SCHED_
25 #define _COMPILE_SCHED_
26
27 #include "compile_vect.hh"
28 #include "loop.hh"
29
30
31 ////////////////////////////////////////////////////////////////////////
32 /**
33 * Compile a list of FAUST signals into a vector C++ class
34 */
35 ///////////////////////////////////////////////////////////////////////
36
37 class SchedulerCompiler : public VectorCompiler
38 {
39
40 public:
41
42 SchedulerCompiler (const string& name, const string& super, int numInputs, int numOutputs)
43 : VectorCompiler(name,super,numInputs,numOutputs)
44 {}
45
46 SchedulerCompiler (Klass* k) : VectorCompiler(k)
47 {}
48 virtual void compileMultiSignal (Tree L);
49
50 protected:
51
52 virtual void vectorLoop (const string& tname, const string& dlname, const string& cexp);
53 virtual void dlineLoop ( const string& tname, const string& dlname, int delay, const string& cexp);
54
55
56 };
57
58
59 #endif