mirror of
https://github.com/microtherion/VocalEasel.git
synced 2025-01-05 09:54:00 +00:00
43 lines
902 B
C++
43 lines
902 B
C++
/*
|
|
* TVLChord.cpp
|
|
* Vocalese
|
|
*
|
|
* Created by Matthias Neeracher on 12/19/05.
|
|
* Copyright 2005 __MyCompanyName__. All rights reserved.
|
|
*
|
|
*/
|
|
|
|
#include "VLModel.h"
|
|
|
|
#include <iostream>
|
|
|
|
int main(int, char *const [])
|
|
{
|
|
std::string chordName;
|
|
|
|
while (std::cin >> chordName) {
|
|
VLChord chord(chordName);
|
|
|
|
std::string baseS, extS, rootS, baseF, extF, rootF, lilyS, lilyF;
|
|
|
|
chord.Name(baseS, extS, rootS, true);
|
|
chord.Name(baseF, extF, rootF, false);
|
|
chord.LilypondName(lilyS, true);
|
|
chord.LilypondName(lilyF, false);
|
|
|
|
std::cout << baseS << "[" << extS << "]" << rootS << " "
|
|
<< baseF << "[" << extF << "]" << rootF << " "
|
|
<< lilyS << " " << lilyF << " (";
|
|
|
|
for (int i=0; i<32; ++i)
|
|
if (chord.fSteps & (1<<i)) {
|
|
VLNote n(1, chord.fPitch+i);
|
|
std::string nn;
|
|
n.Name(nn);
|
|
std::cout << " " << nn;
|
|
}
|
|
std::cout << " )" << std::endl;
|
|
}
|
|
exit(0);
|
|
}
|