comparison src/Support/FileList.cc @ 23:491b1b1d1dc5

-Added AIMCopy, a replacement for HTK's HCopy -Set "Id" keyword on all .cc, .h and .py files -Added FileList class to aupport AIMCopy -Added a first go at a Module factory class. It's not to be used at the moment, but it will serve as a reminder to implement a proper factory soon.
author tomwalters
date Tue, 23 Feb 2010 12:47:01 +0000
parents
children e361baf69120
comparison
equal deleted inserted replaced
22:645cfd371cff 23:491b1b1d1dc5
1 // Copyright 2010, Thomas Walters
2 //
3 // AIM-C: A C++ implementation of the Auditory Image Model
4 // http://www.acousticscale.org/AIMC
5 //
6 // This program is free software: you can redistribute it and/or modify
7 // it under the terms of the GNU General Public License as published by
8 // the Free Software Foundation, either version 3 of the License, or
9 // (at your option) any later version.
10 //
11 // This program is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
15 //
16 // You should have received a copy of the GNU General Public License
17 // along with this program. If not, see <http://www.gnu.org/licenses/>.
18
19 /*!
20 * \file
21 * \brief Convert a file containing a list of pairs of tab-separated
22 * items, one per line, and convert it to a vector<pair<string, string> >
23 *
24 * \author Thomas Walters <tom@acousticscale.org>
25 * \date created 2010/02/23
26 * \version \$Id$
27 */
28
29 #include "Support/FileList.h"
30
31 namespace aimc {
32 vector<pair<string, string> > FileList::Load(string filename) {
33 FILE* file_handle;
34 vector<pair<string, string> > file_list;
35 if ((file_handle = fopen(filename.c_str(), "r"))==NULL) {
36 LOG_ERROR(_T("Couldn't open file '%s' for reading."), filename.c_str());
37 return file_list;
38 }
39
40 string out_1;
41 string out_2;
42 char n1[PATH_MAX];
43 char n2[PATH_MAX];
44 while (fscanf(file_handle, "%s\t%s", n1, n2) != EOF) {
45 out_1 = n1;
46 out_2 = n2;
47 file_list.push_back(make_pair(out_1, out_2));
48 }
49 fclose(file_handle);
50 return file_list;
51 }
52 } // namespace aimc