From d9f92340841944ea000dd13da994feb6293e9f93 Mon Sep 17 00:00:00 2001 From: Koen Punt Date: Tue, 17 Jun 2014 11:58:10 +0200 Subject: [PATCH] Allow gem executable to contain spaces rbenv has a special exec function which loads the correct ruby version before executing a command. The syntax for this is `/usr/local/rbenv/bin/rbenv exec gem ...` for example. But previously when specifying executable='/usr/local/rbenv/bin/rbenv exec gem' this would not work because the string was treated as one executable. This PR fixes that by splitting the executable on spaces. --- library/packaging/gem | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/library/packaging/gem b/library/packaging/gem index 0d1a157a1f..b30d3c16d2 100644 --- a/library/packaging/gem +++ b/library/packaging/gem @@ -91,12 +91,12 @@ import re def get_rubygems_path(module): if module.params['executable']: - return module.params['executable'] + return module.params['executable'].split(' ') else: - return module.get_bin_path('gem', True) + return [ module.get_bin_path('gem', True) ] def get_rubygems_version(module): - cmd = [ get_rubygems_path(module), '--version' ] + cmd = get_rubygems_path(module) + [ '--version' ] (rc, out, err) = module.run_command(cmd, check_rc=True) match = re.match(r'^(\d+)\.(\d+)\.(\d+)', out) @@ -107,7 +107,7 @@ def get_rubygems_version(module): def get_installed_versions(module, remote=False): - cmd = [ get_rubygems_path(module) ] + cmd = get_rubygems_path(module) cmd.append('query') if remote: cmd.append('--remote') @@ -144,7 +144,7 @@ def uninstall(module): if module.check_mode: return - cmd = [ get_rubygems_path(module) ] + cmd = get_rubygems_path(module) cmd.append('uninstall') if module.params['version']: cmd.extend([ '--version', module.params['version'] ]) @@ -165,7 +165,7 @@ def install(module): else: major = None - cmd = [ get_rubygems_path(module) ] + cmd = get_rubygems_path(module) cmd.append('install') if module.params['version']: cmd.extend([ '--version', module.params['version'] ])