Change namings in functor_task and add docs to its __init__
Change-Id: If260cfbeeee60e177c832a143f8ddc9f6fc71600
This commit is contained in:
		| @@ -3,6 +3,7 @@ | |||||||
| # vim: tabstop=4 shiftwidth=4 softtabstop=4 | # vim: tabstop=4 shiftwidth=4 softtabstop=4 | ||||||
|  |  | ||||||
| #    Copyright (C) 2012-2013 Yahoo! Inc. All Rights Reserved. | #    Copyright (C) 2012-2013 Yahoo! Inc. All Rights Reserved. | ||||||
|  | #    Copyright (C) 2013 AT&T Labs Inc. All Rights Reserved. | ||||||
| # | # | ||||||
| #    Licensed under the Apache License, Version 2.0 (the "License"); you may | #    Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||||
| #    not use this file except in compliance with the License. You may obtain | #    not use this file except in compliance with the License. You may obtain | ||||||
| @@ -17,6 +18,7 @@ | |||||||
| #    under the License. | #    under the License. | ||||||
|  |  | ||||||
| import inspect | import inspect | ||||||
|  |  | ||||||
| from taskflow import task as base | from taskflow import task as base | ||||||
|  |  | ||||||
| # These arguments are ones that we will skip when parsing for requirements | # These arguments are ones that we will skip when parsing for requirements | ||||||
| @@ -24,12 +26,12 @@ from taskflow import task as base | |||||||
| AUTO_ARGS = ('self', 'context', 'cls') | AUTO_ARGS = ('self', 'context', 'cls') | ||||||
|  |  | ||||||
|  |  | ||||||
| def _take_arg(a): | def _filter_arg(arg): | ||||||
|     if a in AUTO_ARGS: |     if arg in AUTO_ARGS: | ||||||
|         return False |         return False | ||||||
|     # In certain decorator cases it seems like we get the function to be |     # In certain decorator cases it seems like we get the function to be | ||||||
|     # decorated as an argument, we don't want to take that as a real argument. |     # decorated as an argument, we don't want to take that as a real argument. | ||||||
|     if not isinstance(a, basestring): |     if not isinstance(arg, basestring): | ||||||
|         return False |         return False | ||||||
|     return True |     return True | ||||||
|  |  | ||||||
| @@ -40,31 +42,45 @@ class FunctorTask(base.Task): | |||||||
|     Take any callable and make a task from it. |     Take any callable and make a task from it. | ||||||
|     """ |     """ | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def _callable_name(function): |     def _get_callable_name(execute_with): | ||||||
|         """Generate a name from callable""" |         """Generate a name from callable""" | ||||||
|         im_class = getattr(function, 'im_class', None) |         im_class = getattr(execute_with, 'im_class', None) | ||||||
|         if im_class is not None: |         if im_class is not None: | ||||||
|             parts = (im_class.__module__, im_class.__name__, function.__name__) |             parts = (im_class.__module__, im_class.__name__, | ||||||
|  |                      execute_with.__name__) | ||||||
|         else: |         else: | ||||||
|             parts = (function.__module__, function.__name__) |             parts = (execute_with.__module__, execute_with.__name__) | ||||||
|         return '.'.join(parts) |         return '.'.join(parts) | ||||||
|  |  | ||||||
|     def __init__(self, execute_with, **kwargs): |     def __init__(self, execute_with, **kwargs): | ||||||
|  |         """Initialize FunctorTask instance with given callable and kwargs | ||||||
|  |  | ||||||
|  |         :param execute_with: the callable | ||||||
|  |         :param kwargs: reserved keywords (all optional) are | ||||||
|  |             name: name of the task, default None (auto generate) | ||||||
|  |             task_id:  id of the task, default None (auto generate) | ||||||
|  |             revert_with: the callable to revert, default None | ||||||
|  |             version: version of the task, default Task's version 1.0 | ||||||
|  |             optionals: optionals of the task, default () | ||||||
|  |             provides: provides of the task, default () | ||||||
|  |             requires: requires of the task, default () | ||||||
|  |             auto_extract: auto extract execute_with's args and put it into | ||||||
|  |                 requires, default True | ||||||
|  |         """ | ||||||
|         name = kwargs.pop('name', None) |         name = kwargs.pop('name', None) | ||||||
|  |         task_id = kwargs.pop('task_id', None) | ||||||
|         if name is None: |         if name is None: | ||||||
|             name = self._callable_name(execute_with) |             name = self._get_callable_name(execute_with) | ||||||
|         super(FunctorTask, self).__init__(name, kwargs.pop('task_id', None)) |         super(FunctorTask, self).__init__(name, task_id) | ||||||
|         self._execute_with = execute_with |         self._execute_with = execute_with | ||||||
|         self._revert_with = kwargs.pop('revert_with', None) |         self._revert_with = kwargs.pop('revert_with', None) | ||||||
|         self.version = kwargs.pop('version', self.version) |         self.version = kwargs.pop('version', self.version) | ||||||
|  |         self.optional.update(kwargs.pop('optional', ())) | ||||||
|  |         self.provides.update(kwargs.pop('provides', ())) | ||||||
|         self.requires.update(kwargs.pop('requires', ())) |         self.requires.update(kwargs.pop('requires', ())) | ||||||
|         if kwargs.pop('auto_extract', True): |         if kwargs.pop('auto_extract', True): | ||||||
|             f_args = inspect.getargspec(execute_with).args |             f_args = inspect.getargspec(execute_with).args | ||||||
|             self.requires.update([a for a in f_args if _take_arg(a)]) |             self.requires.update([arg for arg in f_args if _filter_arg(arg)]) | ||||||
|  |  | ||||||
|         self.optional.update(kwargs.pop('optional', ())) |  | ||||||
|         self.provides.update(kwargs.pop('provides', ())) |  | ||||||
|         if kwargs: |         if kwargs: | ||||||
|             raise TypeError('__init__() got an unexpected keyword argument %r' |             raise TypeError('__init__() got an unexpected keyword argument %r' | ||||||
|                             % kwargs.keys[0]) |                             % kwargs.keys[0]) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Changbin Liu
					Changbin Liu