mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 05:23:58 -07:00 
			
		
		
		
	Merge pull request #14277 from ansible/default-shell-type
Establish sh as the default shell plugin.
This commit is contained in:
		
				commit
				
					
						147dba5d97
					
				
			
		
					 5 changed files with 30 additions and 1 deletions
				
			
		|  | @ -84,7 +84,12 @@ class ConnectionBase(with_metaclass(ABCMeta, object)): | ||||||
|         elif hasattr(self, '_shell_type'): |         elif hasattr(self, '_shell_type'): | ||||||
|             shell_type = getattr(self, '_shell_type') |             shell_type = getattr(self, '_shell_type') | ||||||
|         else: |         else: | ||||||
|             shell_type = os.path.basename(C.DEFAULT_EXECUTABLE) |             shell_type = 'sh' | ||||||
|  |             shell_filename = os.path.basename(C.DEFAULT_EXECUTABLE) | ||||||
|  |             for shell in shell_loader.all(): | ||||||
|  |                 if shell_filename in shell.COMPATIBLE_SHELLS: | ||||||
|  |                     shell_type = shell.SHELL_FAMILY | ||||||
|  |                     break | ||||||
| 
 | 
 | ||||||
|         self._shell = shell_loader.get(shell_type) |         self._shell = shell_loader.get(shell_type) | ||||||
|         if not self._shell: |         if not self._shell: | ||||||
|  |  | ||||||
|  | @ -21,6 +21,11 @@ from ansible.plugins.shell.sh import ShellModule as ShModule | ||||||
| 
 | 
 | ||||||
| class ShellModule(ShModule): | class ShellModule(ShModule): | ||||||
| 
 | 
 | ||||||
|  |     # Common shell filenames that this plugin handles | ||||||
|  |     COMPATIBLE_SHELLS = frozenset(('csh', 'tcsh')) | ||||||
|  |     # Family of shells this has.  Must match the filename without extension | ||||||
|  |     SHELL_FAMILY = 'csh' | ||||||
|  | 
 | ||||||
|     # How to end lines in a python script one-liner |     # How to end lines in a python script one-liner | ||||||
|     _SHELL_EMBEDDED_PY_EOL = '\\\n' |     _SHELL_EMBEDDED_PY_EOL = '\\\n' | ||||||
|     _SHELL_REDIRECT_ALLNULL = '>& /dev/null' |     _SHELL_REDIRECT_ALLNULL = '>& /dev/null' | ||||||
|  |  | ||||||
|  | @ -21,6 +21,11 @@ from ansible.plugins.shell.sh import ShellModule as ShModule | ||||||
| 
 | 
 | ||||||
| class ShellModule(ShModule): | class ShellModule(ShModule): | ||||||
| 
 | 
 | ||||||
|  |     # Common shell filenames that this plugin handles | ||||||
|  |     COMPATIBLE_SHELLS = frozenset(('fish',)) | ||||||
|  |     # Family of shells this has.  Must match the filename without extension | ||||||
|  |     SHELL_FAMILY = 'fish' | ||||||
|  | 
 | ||||||
|     _SHELL_AND = '; and' |     _SHELL_AND = '; and' | ||||||
|     _SHELL_OR = '; or' |     _SHELL_OR = '; or' | ||||||
|     _SHELL_SUB_LEFT = '(' |     _SHELL_SUB_LEFT = '(' | ||||||
|  |  | ||||||
|  | @ -36,6 +36,13 @@ if _powershell_version: | ||||||
| 
 | 
 | ||||||
| class ShellModule(object): | class ShellModule(object): | ||||||
| 
 | 
 | ||||||
|  |     # Common shell filenames that this plugin handles | ||||||
|  |     # Powershell is handled differently.  It's selected when winrm is the | ||||||
|  |     # connection | ||||||
|  |     COMPATIBLE_SHELLS = frozenset() | ||||||
|  |     # Family of shells this has.  Must match the filename without extension | ||||||
|  |     SHELL_FAMILY = 'powershell' | ||||||
|  | 
 | ||||||
|     def env_prefix(self, **kwargs): |     def env_prefix(self, **kwargs): | ||||||
|         return '' |         return '' | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -30,6 +30,13 @@ _USER_HOME_PATH_RE = re.compile(r'^~[_.A-Za-z0-9][-_.A-Za-z0-9]*$') | ||||||
| 
 | 
 | ||||||
| class ShellModule(object): | class ShellModule(object): | ||||||
| 
 | 
 | ||||||
|  |     # Common shell filenames that this plugin handles. | ||||||
|  |     # Note: sh is the default shell plugin so this plugin may also be selected | ||||||
|  |     # if the filename is not listed in any Shell plugin. | ||||||
|  |     COMPATIBLE_SHELLS = frozenset(('sh', 'zsh', 'bash', 'dash', 'ksh')) | ||||||
|  |     # Family of shells this has.  Must match the filename without extension | ||||||
|  |     SHELL_FAMILY = 'sh' | ||||||
|  | 
 | ||||||
|     # How to end lines in a python script one-liner |     # How to end lines in a python script one-liner | ||||||
|     _SHELL_EMBEDDED_PY_EOL = '\n' |     _SHELL_EMBEDDED_PY_EOL = '\n' | ||||||
|     _SHELL_REDIRECT_ALLNULL = '> /dev/null 2>&1' |     _SHELL_REDIRECT_ALLNULL = '> /dev/null 2>&1' | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue