diff 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
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/Support/FileList.cc	Tue Feb 23 12:47:01 2010 +0000
@@ -0,0 +1,52 @@
+// Copyright 2010, Thomas Walters
+//
+// AIM-C: A C++ implementation of the Auditory Image Model
+// http://www.acousticscale.org/AIMC
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// This program 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 General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+/*!
+ * \file 
+ * \brief Convert a file containing a list of pairs of tab-separated
+ * items, one per line, and convert it to a vector<pair<string, string> >
+ *
+ * \author Thomas Walters <tom@acousticscale.org>
+ * \date created 2010/02/23
+ * \version \$Id$
+ */
+
+#include "Support/FileList.h"
+
+namespace aimc {
+vector<pair<string, string> > FileList::Load(string filename) {
+  FILE* file_handle;
+  vector<pair<string, string> > file_list;
+  if ((file_handle = fopen(filename.c_str(), "r"))==NULL) {
+		LOG_ERROR(_T("Couldn't open file '%s' for reading."), filename.c_str());
+		return file_list;
+	}
+
+  string out_1;
+  string out_2;
+  char n1[PATH_MAX];
+  char n2[PATH_MAX];
+	while (fscanf(file_handle, "%s\t%s", n1, n2) != EOF) {
+    out_1 = n1;
+    out_2 = n2;
+    file_list.push_back(make_pair(out_1, out_2));
+	}
+  fclose(file_handle);
+  return file_list;
+}
+}  // namespace aimc
\ No newline at end of file