X-Git-Url: http://git.kaliko.me/?p=python-musicpd.git;a=blobdiff_plain;f=mpd.py;h=5e50295df30acb0523d84f5fedd5dfe77048310e;hp=32b51a17e4b324ae79dccd33287c4eae6cc11ebb;hb=a8b38c7c44c731525fdf02c4bf8cec5acfe86031;hpb=03647a81484640a4a6197774408a45973c9dbe39 diff --git a/mpd.py b/mpd.py index 32b51a1..5e50295 100644 --- a/mpd.py +++ b/mpd.py @@ -41,6 +41,9 @@ class CommandListError(MPDError): class PendingCommandError(MPDError): pass +class IteratingError(MPDError): + pass + class _NotConnected(object): def __getattr__(self, attr): @@ -159,6 +162,9 @@ class MPDClient(object): if self._command_list is not None: raise CommandListError("Cannot use fetch_%s in a command list" % command) + if self._iterating: + raise IteratingError("Cannot use fetch_%s while iterating" % + command) if not self._pending: raise PendingCommandError("No pending commands to fetch") if self._pending[0] != command: @@ -170,6 +176,8 @@ class MPDClient(object): return retval() def _execute(self, command, args): + if self._iterating: + raise IteratingError("Cannot execute %s while iterating" % command) if self._pending: raise PendingCommandError("Cannot execute %s with " "pending commands" % command) @@ -261,15 +269,25 @@ class MPDClient(object): yield obj def _read_command_list(self): - for retval in self._command_list: - yield retval() - self._command_list = None + try: + for retval in self._command_list: + yield retval() + finally: + self._command_list = None self._fetch_nothing() + def _iterator_wrapper(self, iterator): + try: + for item in iterator: + yield item + finally: + self._iterating = False + def _wrap_iterator(self, iterator): if not self.iterate: return list(iterator) - return iterator + self._iterating = True + return self._iterator_wrapper(iterator) def _fetch_nothing(self): line = self._read_line() @@ -326,6 +344,7 @@ class MPDClient(object): def _reset(self): self.mpd_version = None + self._iterating = False self._pending = [] self._command_list = None self._sock = None @@ -392,6 +411,8 @@ class MPDClient(object): def command_list_ok_begin(self): if self._command_list is not None: raise CommandListError("Already in command list") + if self._iterating: + raise IteratingError("Cannot begin command list while iterating") if self._pending: raise PendingCommandError("Cannot begin command list " "with pending commands") @@ -401,6 +422,8 @@ class MPDClient(object): def command_list_end(self): if self._command_list is None: raise CommandListError("Not in command list") + if self._iterating: + raise IteratingError("Already iterating over a command list") self._write_command("command_list_end") return self._fetch_command_list()