// // Programmer: Craig Stuart Sapp <craig@ccrma.stanford.edu> // Creation Date: Tue Nov 14 16:32:36 PST 2000 // Last Modified: Tue Nov 14 16:32:39 PST 2000 // Last Modified: Sun Apr 14 21:25:48 PDT 2013 Enabled multiple segment input // Filename: ...sig/examples/all/ditto.cpp // Web Address: http://sig.sapp.org/examples/museinfo/humdrum/ditto.cpp // Syntax: C++; museinfo // // Description: Fills in the meaning of null tokens. // #include "humdrum.h" // function declarations void checkOptions(Options& opts, int argc, char* argv[]); void example(void); void printOutput(HumdrumFile& infile); void usage(const char* command); // global variables Options options; // database for command-line arguments int parensQ = 0; // used with the -p option int kernQ = 0; // used with -k option /////////////////////////////////////////////////////////////////////////// int main(int argc, char* argv[]) { HumdrumFileSet infiles; // process the command-line options checkOptions(options, argc, argv); // figure out the number of input files to process int numinputs = options.getArgCount(); int i; if (numinputs < 1) { infiles.read(cin); } else { for (i=0; i<numinputs; i++) { infiles.readAppend(options.getArg(i+1)); } } for (i=0; i<infiles.getCount(); i++) { if (kernQ) { printKernOutput(infiles[i]); } else { printOutput(infiles[i]); } } return 0; } /////////////////////////////////////////////////////////////////////////// ////////////////////////////// // // checkOptions -- validate and process command-line options. // void checkOptions(Options& opts, int argc, char* argv[]) { opts.define("p|parens=b", "print parentheses around ditto data"); opts.define("author=b"); // author of program opts.define("version=b"); // compilation info opts.define("example=b"); // example usages opts.define("h|help=b"); // short description opts.process(argc, argv); // handle basic options: if (opts.getBoolean("author")) { cout << "Written by Craig Stuart Sapp, " << "craig@ccrma.stanford.edu, Nov 2000" << endl; exit(0); } else if (opts.getBoolean("version")) { cout << argv[0] << ", version: 14 Nov 2000" << endl; cout << "compiled: " << __DATE__ << endl; cout << MUSEINFO_VERSION << endl; exit(0); } else if (opts.getBoolean("help")) { usage(opts.getCommand()); exit(0); } else if (opts.getBoolean("example")) { example(); exit(0); } parensQ = opts.getBoolean("parens"); } ////////////////////////////// // // example -- example usage of the ditto program // void example(void) { cout << " \n" << endl; } ////////////////////////////// // // printOutput -- display the filled results // void printOutput(HumdrumFile& infile) { int i, j; infile.printNonemptySegmentLabel(cout); for (i=0; i<infile.getNumLines(); i++) { if (infile[i].getType() && (E_humrec_data == 0)) { cout << infile[i].getLine() << "\n"; } else { for (j=0; j<infile[i].getFieldCount(); j++) { if (strcmp(infile[i][j], ".") == 0) { if (parensQ) { cout << "("; } cout << infile.getDotValue(i, j); if (parensQ) { cout << ")"; } } else { cout << infile[i][j]; } if (j < infile[i].getFieldCount() - 1) { cout << "\t"; } } cout << "\n"; } } } ////////////////////////////// // // printKernOutput -- Notes are split into a sequence of tied notes. // void printKernOutput(HumdrumFile& infile) { int i, j; infile.analyzeRhythm("4"); infile.printNonemptySegmentLabel(cout); for (i=0; i<infile.getNumLines(); i++) { if (!infile[i].isData) { cout << infile[i].getLine() << "\n"; } else { for (j=0; j<infile[i].getFieldCount(); j++) { if (strcmp(infile[i][j], ".") == 0) { if (parensQ) { cout << "("; } cout << infile.getDotValue(i, j); if (parensQ) { cout << ")"; } } else { cout << infile[i][j]; } if (j < infile[i].getFieldCount() - 1) { cout << "\t"; } } cout << "\n"; } } } ////////////////////////////// // // usage -- gives the usage statement for the ditto program // void usage(const char* command) { cout << " \n" << endl; } // md5sum: fd59e6c3941038fd1f49b8c0a15c8713 ditto.cpp [20050403]