mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
gem_module: Add bindir option
This option allows to specify directory to install executables, e.g. `/home/user/bin` or `/home/user/.local/bin`. This comes especially handy when used with user_install option as the default path of executables is not in PATH.
This commit is contained in:
parent
ee23c26150
commit
12339d2b00
2 changed files with 13 additions and 0 deletions
2
changelogs/fragments/gem_module_add_bindir_option.yml
Normal file
2
changelogs/fragments/gem_module_add_bindir_option.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
minor_changes:
|
||||||
|
- gem module - add ``bindir`` option. This option allows to specify directory to install executables, e.g. ``/home/user/bin`` or ``/home/user/.local/bin``.
|
|
@ -62,6 +62,11 @@ options:
|
||||||
These gems will be independent from the global installed ones.
|
These gems will be independent from the global installed ones.
|
||||||
Specifying this requires user_install to be false.
|
Specifying this requires user_install to be false.
|
||||||
required: false
|
required: false
|
||||||
|
bindir:
|
||||||
|
type: path
|
||||||
|
description:
|
||||||
|
- Install executables into a specific directory.
|
||||||
|
required: false
|
||||||
env_shebang:
|
env_shebang:
|
||||||
description:
|
description:
|
||||||
- Rewrite the shebang line on installed scripts to use /usr/bin/env.
|
- Rewrite the shebang line on installed scripts to use /usr/bin/env.
|
||||||
|
@ -198,6 +203,9 @@ def uninstall(module):
|
||||||
if module.params['install_dir']:
|
if module.params['install_dir']:
|
||||||
cmd.extend(['--install-dir', module.params['install_dir']])
|
cmd.extend(['--install-dir', module.params['install_dir']])
|
||||||
|
|
||||||
|
if module.params['bindir']:
|
||||||
|
cmd.extend(['--bindir', module.params['bindir']])
|
||||||
|
|
||||||
if module.params['version']:
|
if module.params['version']:
|
||||||
cmd.extend(['--version', module.params['version']])
|
cmd.extend(['--version', module.params['version']])
|
||||||
else:
|
else:
|
||||||
|
@ -235,6 +243,8 @@ def install(module):
|
||||||
cmd.append('--no-user-install')
|
cmd.append('--no-user-install')
|
||||||
if module.params['install_dir']:
|
if module.params['install_dir']:
|
||||||
cmd.extend(['--install-dir', module.params['install_dir']])
|
cmd.extend(['--install-dir', module.params['install_dir']])
|
||||||
|
if module.params['bindir']:
|
||||||
|
cmd.extend(['--bindir', module.params['bindir']])
|
||||||
if module.params['pre_release']:
|
if module.params['pre_release']:
|
||||||
cmd.append('--pre')
|
cmd.append('--pre')
|
||||||
if not module.params['include_doc']:
|
if not module.params['include_doc']:
|
||||||
|
@ -265,6 +275,7 @@ def main():
|
||||||
state=dict(required=False, default='present', choices=['present', 'absent', 'latest'], type='str'),
|
state=dict(required=False, default='present', choices=['present', 'absent', 'latest'], type='str'),
|
||||||
user_install=dict(required=False, default=True, type='bool'),
|
user_install=dict(required=False, default=True, type='bool'),
|
||||||
install_dir=dict(required=False, type='path'),
|
install_dir=dict(required=False, type='path'),
|
||||||
|
bindir=dict(required=False, type='path'),
|
||||||
pre_release=dict(required=False, default=False, type='bool'),
|
pre_release=dict(required=False, default=False, type='bool'),
|
||||||
include_doc=dict(required=False, default=False, type='bool'),
|
include_doc=dict(required=False, default=False, type='bool'),
|
||||||
env_shebang=dict(required=False, default=False, type='bool'),
|
env_shebang=dict(required=False, default=False, type='bool'),
|
||||||
|
|
Loading…
Reference in a new issue