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 _COMPILE_SCHED_
23 #define _COMPILE_SCHED_
24 
25 #include "compile_vect.hh"
26 #include "loop.hh"
27 
28 ////////////////////////////////////////////////////////////////////////
29 /**
30  * Compile a list of FAUST signals into a vector C++ class
31  */
32 ///////////////////////////////////////////////////////////////////////
33 
34 class SchedulerCompiler : public VectorCompiler {
35    public:
SchedulerCompiler(const string & name,const string & super,int numInputs,int numOutputs)36     SchedulerCompiler(const string& name, const string& super, int numInputs, int numOutputs)
37         : VectorCompiler(name, super, numInputs, numOutputs)
38     {
39     }
40 
SchedulerCompiler(Klass * k)41     SchedulerCompiler(Klass* k) : VectorCompiler(k) {}
42     virtual void compileMultiSignal(Tree L);
43 
44    protected:
45     virtual void vectorLoop(const string& tname, const string& dlname, const string& cexp, const string& ccs);
46     virtual void dlineLoop(const string& tname, const string& dlname, int delay, const string& cexp, const string& ccs);
47 };
48 
49 #endif
50