mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Make blockinfile work with python3
Traceback (most recent call last): File \"/tmp/ansible_ueg52c0b/ansible_module_blockinfile.py\", line 319, in <module> main() File \"/tmp/ansible_ueg52c0b/ansible_module_blockinfile.py\", line 259, in main if line.startswith(marker0): TypeError: startswith first arg must be bytes or a tuple of bytes, not str Also clean imports while on it.
This commit is contained in:
parent
7b94e3de38
commit
ceec679302
1 changed files with 11 additions and 10 deletions
|
@ -149,7 +149,9 @@ EXAMPLES = r"""
|
||||||
import re
|
import re
|
||||||
import os
|
import os
|
||||||
import tempfile
|
import tempfile
|
||||||
|
from ansible.module_utils.six import b
|
||||||
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
|
from ansible.module_utils._text import to_bytes
|
||||||
|
|
||||||
def write_changes(module, contents, dest):
|
def write_changes(module, contents, dest):
|
||||||
|
|
||||||
|
@ -227,8 +229,8 @@ def main():
|
||||||
|
|
||||||
insertbefore = params['insertbefore']
|
insertbefore = params['insertbefore']
|
||||||
insertafter = params['insertafter']
|
insertafter = params['insertafter']
|
||||||
block = params['block']
|
block = to_bytes(params['block'])
|
||||||
marker = params['marker']
|
marker = to_bytes(params['marker'])
|
||||||
present = params['state'] == 'present'
|
present = params['state'] == 'present'
|
||||||
|
|
||||||
if not present and not path_exists:
|
if not present and not path_exists:
|
||||||
|
@ -244,8 +246,8 @@ def main():
|
||||||
else:
|
else:
|
||||||
insertre = None
|
insertre = None
|
||||||
|
|
||||||
marker0 = re.sub(r'{mark}', 'BEGIN', marker)
|
marker0 = re.sub(b(r'{mark}'), b('BEGIN'), marker)
|
||||||
marker1 = re.sub(r'{mark}', 'END', marker)
|
marker1 = re.sub(b(r'{mark}'), b('END'), marker)
|
||||||
if present and block:
|
if present and block:
|
||||||
# Escape seqeuences like '\n' need to be handled in Ansible 1.x
|
# Escape seqeuences like '\n' need to be handled in Ansible 1.x
|
||||||
if module.ansible_version.startswith('1.'):
|
if module.ansible_version.startswith('1.'):
|
||||||
|
@ -284,9 +286,9 @@ def main():
|
||||||
lines[n0:n0] = blocklines
|
lines[n0:n0] = blocklines
|
||||||
|
|
||||||
if lines:
|
if lines:
|
||||||
result = '\n'.join(lines)
|
result = b('\n').join(lines)
|
||||||
if original is None or original.endswith('\n'):
|
if original is None or original.endswith(b('\n')):
|
||||||
result += '\n'
|
result += b('\n')
|
||||||
else:
|
else:
|
||||||
result = ''
|
result = ''
|
||||||
if original == result:
|
if original == result:
|
||||||
|
@ -313,7 +315,6 @@ def main():
|
||||||
msg, changed = check_file_attrs(module, changed, msg)
|
msg, changed = check_file_attrs(module, changed, msg)
|
||||||
module.exit_json(changed=changed, msg=msg)
|
module.exit_json(changed=changed, msg=msg)
|
||||||
|
|
||||||
# import module snippets
|
|
||||||
from ansible.module_utils.basic import *
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
|
Loading…
Reference in a new issue