/usr/include/csound/CounterpointNode.hpp is in libcsoundac-dev 1:6.10.0~dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 61 62 63 64 65 66 67 68 69 70 71 72 | /*
* C S O U N D
*
* L I C E N S E
*
* This software is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This software 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef COUNTERPOINTNODE_H
#define COUNTERPOINTNODE_H
#if defined(_MSC_VER) && !defined(__GNUC__)
#pragma warning (disable:4786)
#endif
#include "Platform.hpp"
#ifdef SWIG
%module CsoundAC
%{
#include "Node.hpp"
#include "Counterpoint.hpp"
#include <cmath>
%}
%include "std_vector.i"
%template(IntVector) std::vector<int>;
#else
#include "Node.hpp"
#include "Counterpoint.hpp"
#include <cmath>
#endif
namespace csound
{
/**
* Uses Bill Schottstaedt's species counterpoint generator code
* to either (a) generate a counterpoint in species 1, 2, or 3
* for a cantus firmus selected from notes generated by child nodes,
* or (b) attempt to correct the voice leading for species 1, 2, or 3
* counterpoint in notes generated by child nodes.
*/
class SILENCE_PUBLIC CounterpointNode :
public Node,
public Counterpoint
{
public:
enum
{
GenerateCounterpoint = 0,
CorrectCounterpoint = 1
};
int generationMode;
int musicMode;
int species;
size_t voices;
double secondsPerPulse;
std::vector<int> voiceBeginnings;
CounterpointNode();
virtual ~CounterpointNode();
virtual void produceOrTransform(Score &score, size_t beginAt, size_t endAt, const Eigen::MatrixXd &globalCoordinates);
};
}
#endif
|