Browse Source

Refactor open_songbook function

pull/203/head
Oliverpool 9 years ago
parent
commit
6dcf917265
  1. 21
      patacrep/songbook/__init__.py

21
patacrep/songbook/__init__.py

@ -14,7 +14,8 @@ import patacrep
LOGGER = logging.getLogger() LOGGER = logging.getLogger()
def open_songbook(filename): def open_songbook(filename):
"""Open songbook, and return a raw songbook object. """Open a songbook file, and prepare it to
return a raw songbook object.
:param str filename: Filename of the yaml songbook. :param str filename: Filename of the yaml songbook.
:rvalue: dict :rvalue: dict
@ -35,10 +36,21 @@ def open_songbook(filename):
except Exception as error: # pylint: disable=broad-except except Exception as error: # pylint: disable=broad-except
raise patacrep.errors.SongbookError(str(error)) raise patacrep.errors.SongbookError(str(error))
songbook = _add_songbook_defaults(user_songbook) user_songbook['_filepath'] = filename
user_songbook['_basename'] = os.path.splitext(os.path.basename(filename))[0]
return prepare_songbook(user_songbook)
def prepare_songbook(songbook):
"""Prepare a songbook by adding default values and datadirs
Returns a raw songbook object.
:param dict songbook: Initial yaml songbook.
:rvalue: dict
:return: Songbook, as a dictionary.
"""
songbook = _add_songbook_defaults(songbook)
songbook['_filepath'] = filename
songbook['_basename'] = os.path.splitext(os.path.basename(filename))[0]
# Gathering datadirs # Gathering datadirs
songbook['_datadir'] = list(_iter_absolute_datadirs(songbook)) songbook['_datadir'] = list(_iter_absolute_datadirs(songbook))
@ -50,7 +62,6 @@ def open_songbook(filename):
for path in songbook['_datadir'] for path in songbook['_datadir']
] ]
return songbook return songbook
def _add_songbook_defaults(user_songbook): def _add_songbook_defaults(user_songbook):

Loading…
Cancel
Save