|
@ -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): |
|
|