ÿØÿàJFIFÿþ ÿÛC       ÿÛC ÿÀÿÄÿÄ"#QrÿÄÿÄ&1!A"2qQaáÿÚ ?Øy,æ/3JæÝ¹È߲؋5êXw²±ÉyˆR”¾I0ó2—PI¾IÌÚiMö¯–þrìN&"KgX:Šíµ•nTJnLK„…@!‰-ý ùúmë;ºgµŒ&ó±hw’¯Õ@”Ü— 9ñ-ë.²1<yà‚¹ïQÐU„ہ?.’¦èûbß±©Ö«Âw*VŒ) `$‰bØÔŸ’ëXÖ-ËTÜíGÚ3ð«g Ÿ§¯—Jx„–’U/ÂÅv_s(Hÿ@TñJÑãõçn­‚!ÈgfbÓc­:él[ðQe 9ÀPLbÃãCµm[5¿ç'ªjglå‡Ûí_§Úõl-;"PkÞÞÁQâ¼_Ñ^¢SŸx?"¸¦ùY騐ÒOÈ q’`~~ÚtËU¹CڒêV  I1Áß_ÿÙ# Copyright 2014-2015 Nathan West # # This file is part of autocommand. # # autocommand is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # autocommand 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 Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with autocommand. If not, see . from .autoparse import autoparse from .automain import automain try: from .autoasync import autoasync except ImportError: # pragma: no cover pass def autocommand( module, *, description=None, epilog=None, add_nos=False, parser=None, loop=None, forever=False, pass_loop=False): if callable(module): raise TypeError('autocommand requires a module name argument') def autocommand_decorator(func): # Step 1: if requested, run it all in an asyncio event loop. autoasync # patches the __signature__ of the decorated function, so that in the # event that pass_loop is True, the `loop` parameter of the original # function will *not* be interpreted as a command-line argument by # autoparse if loop is not None or forever or pass_loop: func = autoasync( func, loop=None if loop is True else loop, pass_loop=pass_loop, forever=forever) # Step 2: create parser. We do this second so that the arguments are # parsed and passed *before* entering the asyncio event loop, if it # exists. This simplifies the stack trace and ensures errors are # reported earlier. It also ensures that errors raised during parsing & # passing are still raised if `forever` is True. func = autoparse( func, description=description, epilog=epilog, add_nos=add_nos, parser=parser) # Step 3: call the function automatically if __name__ == '__main__' (or # if True was provided) func = automain(module)(func) return func return autocommand_decorator