mirror of
https://github.com/ansible-collections/community.general.git
synced 2026-05-07 13:52:54 +00:00
Allow specifying the output encoding in the template module (#42171)
Allow specifying the source and destination files' encodings in the template module * Added output_encoding to the template module, default to utf-8 * Added documentation for the new variables * Leveraged the encoding argument on to_text() and to_bytes() to keep the implementation as simple as possible * Added integration tests with files in utf-8 and windows-1252 encodings, testing all combinations * fix bad smell test by excluding windows-1252 files from the utf8 checks * fix bad smell test by excluding valid files from the smart quote test
This commit is contained in:
committed by
Toshio Kuratomi
parent
5b4a7cc283
commit
19dc267e4c
@@ -106,6 +106,13 @@ options:
|
||||
may be specified as a symbolic mode (for example, C(u+rwx) or C(u=rw,g=r,o=r)). As of
|
||||
version 2.6, the mode may also be the special string C(preserve). C(preserve) means that
|
||||
the file will be given the same permissions as the source file."
|
||||
output_encoding:
|
||||
description:
|
||||
- Overrides the encoding used to write the template file defined by C(dest).
|
||||
- It defaults to C('utf-8'), but any encoding supported by python can be used.
|
||||
- The source template file must always be encoded using C('utf-8'), for homogeneity.
|
||||
default: 'utf-8'
|
||||
version_added: "2.7"
|
||||
notes:
|
||||
- For Windows you can use M(win_template) which uses '\\r\\n' as C(newline_sequence).
|
||||
- Including a string that uses a date in the template will result in the template being marked 'changed' each time
|
||||
|
||||
@@ -58,6 +58,7 @@ class ActionModule(ActionBase):
|
||||
block_end_string = self._task.args.get('block_end_string', None)
|
||||
trim_blocks = boolean(self._task.args.get('trim_blocks', True), strict=False)
|
||||
lstrip_blocks = boolean(self._task.args.get('lstrip_blocks', False), strict=False)
|
||||
output_encoding = self._task.args.get('output_encoding', 'utf-8') or 'utf-8'
|
||||
|
||||
# Option `lstrip_blocks' was added in Jinja2 version 2.7.
|
||||
if lstrip_blocks:
|
||||
@@ -176,13 +177,14 @@ class ActionModule(ActionBase):
|
||||
new_task.args.pop('variable_end_string', None)
|
||||
new_task.args.pop('trim_blocks', None)
|
||||
new_task.args.pop('lstrip_blocks', None)
|
||||
new_task.args.pop('output_encoding', None)
|
||||
|
||||
local_tempdir = tempfile.mkdtemp(dir=C.DEFAULT_LOCAL_TMP)
|
||||
|
||||
try:
|
||||
result_file = os.path.join(local_tempdir, os.path.basename(source))
|
||||
with open(to_bytes(result_file, errors='surrogate_or_strict'), 'wb') as f:
|
||||
f.write(to_bytes(resultant, errors='surrogate_or_strict'))
|
||||
f.write(to_bytes(resultant, encoding=output_encoding, errors='surrogate_or_strict'))
|
||||
|
||||
new_task.args.update(
|
||||
dict(
|
||||
|
||||
Reference in New Issue
Block a user