mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	* Once cli args are parsed, they're constant.  So, save the parsed args
  into the global context for everyone else to use them from now on.
* Port cli scripts to use the CLIARGS in the context
* Refactor call to parse cli args into the run() method
* Fix unittests for changes to the internals of CLI arg parsing
* Port callback plugins to use context.CLIARGS
  * Got rid of the private self._options attribute
  * Use context.CLIARGS in the individual callback plugins instead.
  * Also output positional arguments in default and unixy plugins
  * Code has been simplified since we're now dealing with a dict rather
    than Optparse.Value
		
	
			
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| ########################################################################
 | |
| #
 | |
| # (C) 2015, Brian Coca <bcoca@ansible.com>
 | |
| #
 | |
| # This file is part of Ansible
 | |
| #
 | |
| # Ansible is free software: you can redistribute it and/or modify
 | |
| # it under the terms of the GNU General Public License as published by
 | |
| # the Free Software Foundation, either version 3 of the License, or
 | |
| # (at your option) any later version.
 | |
| #
 | |
| # Ansible 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 General Public License for more details.
 | |
| #
 | |
| # You should have received a copy of the GNU General Public License
 | |
| # along with Ansible.  If not, see <http://www.gnu.org/licenses/>.
 | |
| #
 | |
| ########################################################################
 | |
| ''' This manages remote shared Ansible objects, mainly roles'''
 | |
| 
 | |
| from __future__ import (absolute_import, division, print_function)
 | |
| __metaclass__ = type
 | |
| 
 | |
| import os
 | |
| 
 | |
| from ansible import context
 | |
| from ansible.errors import AnsibleError
 | |
| from ansible.module_utils.six import string_types
 | |
| 
 | |
| #      default_readme_template
 | |
| #      default_meta_template
 | |
| 
 | |
| 
 | |
| class Galaxy(object):
 | |
|     ''' Keeps global galaxy info '''
 | |
| 
 | |
|     def __init__(self):
 | |
| 
 | |
|         # roles_path needs to be a list and will be by default
 | |
|         roles_path = context.CLIARGS.get('roles_path', tuple())
 | |
|         # cli option handling is responsible for splitting roles_path
 | |
|         self.roles_paths = roles_path
 | |
| 
 | |
|         self.roles = {}
 | |
| 
 | |
|         # load data path for resource usage
 | |
|         this_dir, this_filename = os.path.split(__file__)
 | |
|         type_path = context.CLIARGS.get('role_type', "default")
 | |
|         self.DATA_PATH = os.path.join(this_dir, 'data', type_path)
 | |
| 
 | |
|     @property
 | |
|     def default_role_skeleton_path(self):
 | |
|         return self.DATA_PATH
 | |
| 
 | |
|     def add_role(self, role):
 | |
|         self.roles[role.name] = role
 | |
| 
 | |
|     def remove_role(self, role_name):
 | |
|         del self.roles[role_name]
 |