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 #ifndef __RECSCHEMA__ 00023 #define __RECSCHEMA__ 00024 00025 00026 #include "schema.h" 00027 00028 00033 class recSchema : public schema 00034 { 00035 schema* fSchema1; 00036 schema* fSchema2; 00037 vector<point> fInputPoint; 00038 vector<point> fOutputPoint; 00039 00040 public: 00041 friend schema* makeRecSchema (schema* s1, schema* s2); 00042 00043 virtual void place(double ox, double oy, int orientation); 00044 virtual void draw(device& dev); 00045 virtual point inputPoint(unsigned int i) const; 00046 virtual point outputPoint(unsigned int i) const; 00047 00048 private: 00049 recSchema (schema* s1, schema* s2, double width); 00050 void drawDelaySign(device& dev, double x, double y, double size); 00051 void drawFeedback(device& dev, const point& src, const point& dst, double dx); 00052 void drawFeedfront(device& dev, const point& src, const point& dst, double dx); 00053 00054 }; 00055 00056 00057 #endif 00058 00059