summaryrefslogtreecommitdiffstats
path: root/arts/modules/synth/synth_debug_impl.cpp
blob: 456f4a6f8b8f3d4a7164b522dafcefd4c8b0a0d5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
    /*

    Copyright (C) 2000 Jeff Tranter
                       tranter@pobox.com

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Library General Public
    License as published by the Free Software Foundation; either
    version 2 of the License, or (at your option) any later version.

    This library 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
    Library General Public License for more details.

    You should have received a copy of the GNU Library General Public License
    along with this library; see the file COPYING.LIB.  If not, write to
    the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
    Boston, MA 02110-1301, USA.

    */

#include <stdio.h>
#include "artsmodulessynth.h"
#include "stdsynthmodule.h"

using namespace std;
using namespace Arts;

// You can use this for debugging. It will print out the value of the
// signal at invalue in regular intervals (ca. 1 second), combined
// with the comment you have specified. That way you can find out if
// some signals stay in certain ranges, or if they are there at all.

class Synth_DEBUG_impl : virtual public Synth_DEBUG_skel,
							virtual public StdSynthModule
{
protected:
	string _comment;
	int i;

public:
	string comment() { return _comment; }

  void comment(const string &newComment) { _comment = newComment; }

	void streamInit() { i = 0; }

	void calculateBlock(unsigned long samples)
	{
		for (unsigned long j=0; j<samples; j++)
		{
			i++;
			if ((i % 65536) == 0)
				printf("Synth_DEBUG: %s %f\n", _comment.c_str(), invalue[j]);
		}
	}
};

REGISTER_IMPLEMENTATION(Synth_DEBUG_impl);