- footer = open(footer_path, "r")
- for line in footer:
- sys.stdout.write(line)
-
-parser = argparse.ArgumentParser(description='Generate an HTML containing information about the MP3 files.')
-parser.add_argument('dir', help='The directory containing the MP3 files')
-parser.add_argument("--config", help="The directory containing the configuration")
-
-args = parser.parse_args()
-
-if (args.config is None):
- cfg_dir = os.path.dirname(sys.argv[0])
-else:
- cfg_dir = args.config
-
-copy_header(cfg_dir)
-
-files = []
-for root, dirnames, filenames in os.walk(args.dir):
- for filename in fnmatch.filter(filenames, '*.mp3'):
- files.append(os.path.join(root, filename))
-
-for f in files:
- tag = eyeD3.Tag()
-
- tag.link(f)
-
- print("\t<tr>")
-
- print("\t\t<td>" + tag.getArtist().encode("UTF8") + "</td>\n")
- print("\t\t<td>" + tag.getAlbum().encode("UTF-8") + "</td>")
- print("\t\t<td>" + tag.getTitle().encode("UTF-8") + "</td>")
-
- comments = tag.getComments()
- strComments = ""
- for c in comments:
- strComments += c.comment
-
- p = re.compile("URL: (.*)\r\nComments: (.*)\r\nCurators?: (.*)\r\nCopyright: (.*)")
- m = p.match(strComments)
-
- if m is None:
- url = ""
- curator = ""
- copyright = ""
- else:
- if m.group(2) == "http://freemusicarchive.org/":
- strComments = ""
- url = "<a href=\"" + m.group(1) + "\">FMA</a>"
+ try:
+ footer = open(footer_path, "r")
+ for line in footer:
+ sys.stdout.write(line)
+ footer.close()
+ except IOError as e:
+ sys.stderr.write("Failed to read footer file "
+ + footer_path
+ + ": " + e.strerror + "\n")
+ raise
+
+def generate(mp3_dir, cfg_dir):
+ copy_header(cfg_dir)
+
+ files = []
+ for root, dirnames, filenames in os.walk(mp3_dir):
+ for filename in fnmatch.filter(filenames, '*.mp3'):
+ files.append(os.path.join(root, filename))
+
+ for f in files:
+ tag = eyeD3.Tag()
+
+ tag.link(f)
+
+ print("\t<tr>")
+
+ print("\t\t<td>" + tag.getArtist().encode("UTF8") + "</td>\n")
+ print("\t\t<td>" + tag.getAlbum().encode("UTF-8") + "</td>")
+ print("\t\t<td>" + tag.getTitle().encode("UTF-8") + "</td>")
+
+ comments = tag.getComments()
+ strComments = ""
+ for c in comments:
+ strComments += c.comment
+
+ p = re.compile("URL: (.*)\r\nComments: (.*)\r\nCurators?: (.*)\r\nCopyright: (.*)")
+ m = p.match(strComments)
+
+ if m is None:
+ url = ""
+ curator = ""
+ copyright = ""