|
FAUST compiler
0.9.9.6b8
|
00001 /************************************************************************ 00002 ************************************************************************ 00003 FAUST compiler 00004 Copyright (C) 2003-2004 GRAME, Centre National de Creation Musicale 00005 --------------------------------------------------------------------- 00006 This program is free software; you can redistribute it and/or modify 00007 it under the terms of the GNU General Public License as published by 00008 the Free Software Foundation; either version 2 of the License, or 00009 (at your option) any later version. 00010 00011 This program is distributed in the hope that it will be useful, 00012 but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 GNU General Public License for more details. 00015 00016 You should have received a copy of the GNU General Public License 00017 along with this program; if not, write to the Free Software 00018 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 00019 ************************************************************************ 00020 ************************************************************************/ 00021 00022 00023 #include "schema.h" 00024 #include <assert.h> 00025 00026 using namespace std; 00027 00028 00029 void collector::computeVisibleTraits() 00030 { 00031 bool modified; 00032 00033 do { 00034 modified = false; 00035 for (set<trait>::iterator p = fTraits.begin(); p != fTraits.end(); p++) { 00036 if (fWithInput.count(*p) == 0) { // not connected to a real output 00037 if (fOutputs.count(p->start) > 0) { 00038 fWithInput.insert(*p); // the cable is connected to a real output 00039 fOutputs.insert(p->end); // end become a real output too 00040 modified = true; 00041 } 00042 } 00043 if (fWithOutput.count(*p) == 0) { // not connected to a real input 00044 if (fInputs.count(p->end) > 0) { 00045 fWithOutput.insert(*p); // the cable is connected to a real input 00046 fInputs.insert(p->start); // start become a real input too 00047 modified = true; 00048 } 00049 } 00050 } 00051 } while (modified); 00052 } 00053 00054 bool collector::isVisible(const trait& t) 00055 { 00056 return fWithInput.count(t) && fWithOutput.count(t); 00057 } 00058 00059 void collector::draw(device& dev) 00060 { 00061 computeVisibleTraits(); 00062 for (set<trait>::iterator p = fTraits.begin(); p != fTraits.end(); p++) { 00063 if (isVisible(*p)) p->draw(dev); 00064 } 00065 } 00066
1.8.0