mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
Update module_utils.six to latest (#22855)
* Update module_utils.six to latest We've been held back on the version of six we could use on the module side to 1.4.x because of python-2.4 compatibility. Now that our minimum is Python-2.6, we can update to the latest version of six in module_utils and get rid of the second copy in lib/ansible/compat.
This commit is contained in:
parent
c7c8481181
commit
2fff690caa
127 changed files with 404 additions and 911 deletions
|
@ -16,6 +16,7 @@ Ansible Changes By Release
|
||||||
### Minor Changes
|
### Minor Changes
|
||||||
* removed previously deprecated config option 'hostfile' and env var 'ANSIBLE_HOSTS'
|
* removed previously deprecated config option 'hostfile' and env var 'ANSIBLE_HOSTS'
|
||||||
* removed unused and deprecated config option 'pattern'
|
* removed unused and deprecated config option 'pattern'
|
||||||
|
* Updated the copy of six bundled for modules to use from 1.4.1 to 1.10.0
|
||||||
|
|
||||||
|
|
||||||
#### New: Tests
|
#### New: Tests
|
||||||
|
|
|
@ -53,20 +53,20 @@ import os
|
||||||
import argparse
|
import argparse
|
||||||
import re
|
import re
|
||||||
|
|
||||||
from ansible.compat.six.moves import configparser
|
|
||||||
|
|
||||||
try:
|
|
||||||
from apstra.aosom.session import Session
|
|
||||||
|
|
||||||
HAS_AOS_PYEZ = True
|
|
||||||
except ImportError:
|
|
||||||
HAS_AOS_PYEZ = False
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import json
|
import json
|
||||||
except ImportError:
|
except ImportError:
|
||||||
import simplejson as json
|
import simplejson as json
|
||||||
|
|
||||||
|
try:
|
||||||
|
from apstra.aosom.session import Session
|
||||||
|
HAS_AOS_PYEZ = True
|
||||||
|
except ImportError:
|
||||||
|
HAS_AOS_PYEZ = False
|
||||||
|
|
||||||
|
from ansible.module_utils.six.moves import configparser
|
||||||
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
##
|
##
|
||||||
Expected output format in Device mode
|
Expected output format in Device mode
|
||||||
|
|
|
@ -41,7 +41,7 @@ The following is a list of module_utils files and a general description. The mod
|
||||||
- redhat.py - Functions for modules that manage Red Hat Network registration and subscriptions
|
- redhat.py - Functions for modules that manage Red Hat Network registration and subscriptions
|
||||||
- service.py - Contains utilities to enable modules to work with Linux services (placeholder, not in use).
|
- service.py - Contains utilities to enable modules to work with Linux services (placeholder, not in use).
|
||||||
- shell.py - Functions to allow modules to create shells and work with shell commands
|
- shell.py - Functions to allow modules to create shells and work with shell commands
|
||||||
- six.py - Module utils for working with the Six python 2 and 3 compatibility library
|
- six/__init__.py - Bundled copy of the `Six Python library <https://pythonhosted.org/six/>`_ to aid in writing code compatible with both Python 2 and Python 3.
|
||||||
- splitter.py - String splitting and manipulation utilities for working with Jinja2 templates
|
- splitter.py - String splitting and manipulation utilities for working with Jinja2 templates
|
||||||
- urls.py - Utilities for working with http and https requests
|
- urls.py - Utilities for working with http and https requests
|
||||||
- vca.py - Contains utilities for modules that work with VMware vCloud Air
|
- vca.py - Contains utilities for modules that work with VMware vCloud Air
|
||||||
|
|
|
@ -325,20 +325,16 @@ Bundled six
|
||||||
|
|
||||||
The third-party `python-six <https://pythonhosted.org/six/>`_ library exists
|
The third-party `python-six <https://pythonhosted.org/six/>`_ library exists
|
||||||
to help projects create code that runs on both Python-2 and Python-3. Ansible
|
to help projects create code that runs on both Python-2 and Python-3. Ansible
|
||||||
includes version 1.4.1 in module_utils so that other modules can use it
|
includes a version of the library in module_utils so that other modules can use it
|
||||||
without requiring that it is installed on the remote system. To make use of
|
without requiring that it is installed on the remote system. To make use of
|
||||||
it, import it like this::
|
it, import it like this::
|
||||||
|
|
||||||
from ansible.module_utils import six
|
from ansible.module_utils import six
|
||||||
|
|
||||||
.. note:: Why version 1.4.1?
|
.. note:: Ansible can also use a system copy of six
|
||||||
|
|
||||||
six-1.4.1 is the last version of python-six to support Python-2.4. Until
|
Ansible will use a system copy of six if the system copy is a later
|
||||||
Ansible-2.4, most Ansible modules were required to run on Python-2.4. So
|
version than the one Ansible bundles.
|
||||||
the bundled version of six could not be newer than 1.4.1.
|
|
||||||
|
|
||||||
Ansible-2.4 now targets Python-2.6 or greater for modules. We'll be
|
|
||||||
updating the bundled six soon.
|
|
||||||
|
|
||||||
-------------------------------------
|
-------------------------------------
|
||||||
Porting module_utils code to Python 3
|
Porting module_utils code to Python 3
|
||||||
|
|
|
@ -33,8 +33,8 @@ from abc import ABCMeta, abstractmethod
|
||||||
|
|
||||||
from ansible.release import __version__
|
from ansible.release import __version__
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import with_metaclass
|
|
||||||
from ansible.errors import AnsibleError, AnsibleOptionsError
|
from ansible.errors import AnsibleError, AnsibleOptionsError
|
||||||
|
from ansible.module_utils.six import with_metaclass
|
||||||
from ansible.module_utils._text import to_bytes, to_text
|
from ansible.module_utils._text import to_bytes, to_text
|
||||||
from ansible.utils.path import unfrackpath
|
from ansible.utils.path import unfrackpath
|
||||||
|
|
||||||
|
|
|
@ -25,12 +25,11 @@ import traceback
|
||||||
import textwrap
|
import textwrap
|
||||||
import yaml
|
import yaml
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError, AnsibleOptionsError
|
|
||||||
from ansible.plugins import module_loader, action_loader, lookup_loader, callback_loader, cache_loader, connection_loader, strategy_loader
|
|
||||||
from ansible.cli import CLI
|
from ansible.cli import CLI
|
||||||
|
from ansible.errors import AnsibleError, AnsibleOptionsError
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
|
from ansible.plugins import module_loader, action_loader, lookup_loader, callback_loader, cache_loader, connection_loader, strategy_loader
|
||||||
from ansible.utils import plugin_docs
|
from ansible.utils import plugin_docs
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -1,54 +0,0 @@
|
||||||
# (c) 2014, Toshio Kuratomi <tkuratomi@ansible.com>
|
|
||||||
#
|
|
||||||
# This file is part of Ansible
|
|
||||||
#
|
|
||||||
# Ansible is free software: you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# Ansible is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# Make coding more python3-ish
|
|
||||||
from __future__ import (absolute_import, division, print_function)
|
|
||||||
__metaclass__ = type
|
|
||||||
|
|
||||||
'''
|
|
||||||
Compat six library. RHEL7 has python-six 1.3.0 which is too old
|
|
||||||
'''
|
|
||||||
# The following makes it easier for us to script updates of the bundled code
|
|
||||||
_BUNDLED_METADATA = { "pypi_name": "six", "version": "1.10.0" }
|
|
||||||
|
|
||||||
import os.path
|
|
||||||
|
|
||||||
try:
|
|
||||||
import six as _system_six
|
|
||||||
except ImportError:
|
|
||||||
_system_six = None
|
|
||||||
|
|
||||||
if _system_six:
|
|
||||||
# If we need some things from even newer versions of six, then we need to
|
|
||||||
# use our bundled copy instead
|
|
||||||
|
|
||||||
if ( # Added in six-1.8.0
|
|
||||||
not hasattr(_system_six.moves, 'shlex_quote') or
|
|
||||||
# Added in six-1.4.0
|
|
||||||
not hasattr(_system_six, 'byte2int') or
|
|
||||||
not hasattr(_system_six, 'add_metaclass') or
|
|
||||||
not hasattr(_system_six.moves, 'urllib')
|
|
||||||
):
|
|
||||||
|
|
||||||
_system_six = False
|
|
||||||
|
|
||||||
if _system_six:
|
|
||||||
six = _system_six
|
|
||||||
else:
|
|
||||||
from . import _six as six
|
|
||||||
six_py_file = '{0}.py'.format(os.path.splitext(six.__file__)[0])
|
|
||||||
exec(open(six_py_file, 'rb').read())
|
|
|
@ -23,9 +23,9 @@ import os
|
||||||
import tempfile
|
import tempfile
|
||||||
from string import ascii_letters, digits
|
from string import ascii_letters, digits
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.compat.six.moves import configparser
|
|
||||||
from ansible.errors import AnsibleOptionsError
|
from ansible.errors import AnsibleOptionsError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
from ansible.module_utils.six.moves import configparser
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.parsing.quoting import unquote
|
from ansible.parsing.quoting import unquote
|
||||||
from ansible.utils.path import makedirs_safe
|
from ansible.utils.path import makedirs_safe
|
||||||
|
|
|
@ -406,7 +406,11 @@ class ModuleDepFinder(ast.NodeVisitor):
|
||||||
self.generic_visit(node)
|
self.generic_visit(node)
|
||||||
|
|
||||||
def visit_ImportFrom(self, node):
|
def visit_ImportFrom(self, node):
|
||||||
if node.module.startswith('ansible.module_utils'):
|
# Specialcase: six is a special case because of its
|
||||||
|
# import logic
|
||||||
|
if node.names[0].name == '_six':
|
||||||
|
self.submodules.add(('_six',))
|
||||||
|
elif node.module.startswith('ansible.module_utils'):
|
||||||
where_from = node.module[self.IMPORT_PREFIX_SIZE:]
|
where_from = node.module[self.IMPORT_PREFIX_SIZE:]
|
||||||
if where_from:
|
if where_from:
|
||||||
# from ansible.module_utils.MODULE1[.MODULEn] import IDENTIFIER [as asname]
|
# from ansible.module_utils.MODULE1[.MODULEn] import IDENTIFIER [as asname]
|
||||||
|
@ -484,6 +488,12 @@ def recursive_finder(name, data, py_module_names, py_module_cache, zf):
|
||||||
module_info = imp.find_module('six', module_utils_paths)
|
module_info = imp.find_module('six', module_utils_paths)
|
||||||
py_module_name = ('six',)
|
py_module_name = ('six',)
|
||||||
idx = 0
|
idx = 0
|
||||||
|
elif py_module_name[0] == '_six':
|
||||||
|
# Special case the python six library because it messes up the
|
||||||
|
# import process in an incompatible way
|
||||||
|
module_info = imp.find_module('_six', [os.path.join(p, 'six') for p in module_utils_paths])
|
||||||
|
py_module_name = ('six', '_six')
|
||||||
|
idx = 0
|
||||||
else:
|
else:
|
||||||
# Check whether either the last or the second to last identifier is
|
# Check whether either the last or the second to last identifier is
|
||||||
# a module name
|
# a module name
|
||||||
|
@ -499,7 +509,7 @@ def recursive_finder(name, data, py_module_names, py_module_cache, zf):
|
||||||
|
|
||||||
# Could not find the module. Construct a helpful error message.
|
# Could not find the module. Construct a helpful error message.
|
||||||
if module_info is None:
|
if module_info is None:
|
||||||
msg = ['Could not find imported module support code for %s. Looked for' % name]
|
msg = ['Could not find imported module support code for %s. Looked for' % (name,)]
|
||||||
if idx == 2:
|
if idx == 2:
|
||||||
msg.append('either %s.py or %s.py' % (py_module_name[-1], py_module_name[-2]))
|
msg.append('either %s.py or %s.py' % (py_module_name[-1], py_module_name[-2]))
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -21,14 +21,14 @@ __metaclass__ = type
|
||||||
|
|
||||||
import fnmatch
|
import fnmatch
|
||||||
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.module_utils.six import cmp
|
from ansible.module_utils.six import iteritems
|
||||||
from ansible.playbook.block import Block
|
from ansible.playbook.block import Block
|
||||||
from ansible.playbook.task import Task
|
from ansible.playbook.task import Task
|
||||||
from ansible.playbook.role_include import IncludeRole
|
from ansible.playbook.role_include import IncludeRole
|
||||||
|
|
||||||
|
|
||||||
boolean = C.mk_boolean
|
boolean = C.mk_boolean
|
||||||
|
|
||||||
__all__ = ['PlayIterator']
|
__all__ = ['PlayIterator']
|
||||||
|
|
|
@ -24,11 +24,10 @@ import sys
|
||||||
import time
|
import time
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types, binary_type
|
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError, AnsibleParserError, AnsibleUndefinedVariable, AnsibleConnectionFailure
|
from ansible.errors import AnsibleError, AnsibleParserError, AnsibleUndefinedVariable, AnsibleConnectionFailure
|
||||||
from ansible.executor.task_result import TaskResult
|
from ansible.executor.task_result import TaskResult
|
||||||
|
from ansible.module_utils.six import iteritems, string_types, binary_type
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.playbook.conditional import Conditional
|
from ansible.playbook.conditional import Conditional
|
||||||
from ansible.playbook.task import Task
|
from ansible.playbook.task import Task
|
||||||
|
@ -44,6 +43,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
__all__ = ['TaskExecutor']
|
__all__ = ['TaskExecutor']
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -24,10 +24,10 @@ import os
|
||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.executor.play_iterator import PlayIterator
|
from ansible.executor.play_iterator import PlayIterator
|
||||||
from ansible.executor.stats import AggregateStats
|
from ansible.executor.stats import AggregateStats
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.playbook.block import Block
|
from ansible.playbook.block import Block
|
||||||
from ansible.playbook.play_context import PlayContext
|
from ansible.playbook.play_context import PlayContext
|
||||||
|
@ -44,6 +44,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
__all__ = ['TaskQueueManager']
|
__all__ = ['TaskQueueManager']
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -25,9 +25,8 @@ __metaclass__ = type
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
|
||||||
# default_readme_template
|
# default_readme_template
|
||||||
# default_meta_template
|
# default_meta_template
|
||||||
|
|
|
@ -25,11 +25,11 @@ __metaclass__ = type
|
||||||
import json
|
import json
|
||||||
|
|
||||||
import ansible.constants as C
|
import ansible.constants as C
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.compat.six.moves.urllib.error import HTTPError
|
|
||||||
from ansible.compat.six.moves.urllib.parse import quote as urlquote, urlencode
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.galaxy.token import GalaxyToken
|
from ansible.galaxy.token import GalaxyToken
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
from ansible.module_utils.six.moves.urllib.error import HTTPError
|
||||||
|
from ansible.module_utils.six.moves.urllib.parse import quote as urlquote, urlencode
|
||||||
from ansible.module_utils._text import to_native, to_text
|
from ansible.module_utils._text import to_native, to_text
|
||||||
from ansible.module_utils.urls import open_url
|
from ansible.module_utils.urls import open_url
|
||||||
|
|
||||||
|
|
|
@ -25,10 +25,9 @@ __metaclass__ = type
|
||||||
import getpass
|
import getpass
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from ansible.compat.six.moves.urllib.parse import quote as urlquote, urlparse
|
|
||||||
from ansible.compat.six.moves.urllib.error import HTTPError
|
|
||||||
|
|
||||||
from ansible.errors import AnsibleError, AnsibleOptionsError
|
from ansible.errors import AnsibleError, AnsibleOptionsError
|
||||||
|
from ansible.module_utils.six.moves.urllib.parse import quote as urlquote, urlparse
|
||||||
|
from ansible.module_utils.six.moves.urllib.error import HTTPError
|
||||||
from ansible.module_utils.urls import open_url
|
from ansible.module_utils.urls import open_url
|
||||||
from ansible.utils.color import stringc
|
from ansible.utils.color import stringc
|
||||||
|
|
||||||
|
@ -38,6 +37,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
class GalaxyLogin(object):
|
class GalaxyLogin(object):
|
||||||
''' Class to handle authenticating user with Galaxy API prior to performing CUD operations '''
|
''' Class to handle authenticating user with Galaxy API prior to performing CUD operations '''
|
||||||
|
|
||||||
|
|
|
@ -26,14 +26,13 @@ import sys
|
||||||
import re
|
import re
|
||||||
import itertools
|
import itertools
|
||||||
|
|
||||||
from ansible.compat.six import string_types, iteritems
|
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
|
||||||
from ansible.inventory.dir import InventoryDirectory, get_file_parser
|
from ansible.inventory.dir import InventoryDirectory, get_file_parser
|
||||||
from ansible.inventory.group import Group
|
from ansible.inventory.group import Group
|
||||||
from ansible.inventory.host import Host
|
from ansible.inventory.host import Host
|
||||||
|
from ansible.module_utils.six import string_types, iteritems
|
||||||
from ansible.module_utils._text import to_bytes, to_text
|
from ansible.module_utils._text import to_bytes, to_text
|
||||||
from ansible.parsing.utils.addresses import parse_address
|
from ansible.parsing.utils.addresses import parse_address
|
||||||
from ansible.plugins import vars_loader
|
from ansible.plugins import vars_loader
|
||||||
|
|
|
@ -24,13 +24,12 @@ import subprocess
|
||||||
import sys
|
import sys
|
||||||
from collections import Mapping
|
from collections import Mapping
|
||||||
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.inventory.host import Host
|
from ansible.inventory.host import Host
|
||||||
from ansible.inventory.group import Group
|
from ansible.inventory.group import Group
|
||||||
from ansible.module_utils.basic import json_dict_bytes_to_unicode
|
from ansible.module_utils.basic import json_dict_bytes_to_unicode
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
from ansible.module_utils._text import to_native, to_text
|
from ansible.module_utils._text import to_native, to_text
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -26,8 +26,9 @@ from ansible.inventory.host import Host
|
||||||
from ansible.inventory.group import Group
|
from ansible.inventory.group import Group
|
||||||
from ansible.inventory.expand_hosts import detect_range
|
from ansible.inventory.expand_hosts import detect_range
|
||||||
from ansible.inventory.expand_hosts import expand_hostname_range
|
from ansible.inventory.expand_hosts import expand_hostname_range
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.parsing.utils.addresses import parse_address
|
from ansible.parsing.utils.addresses import parse_address
|
||||||
from ansible.compat.six import string_types
|
|
||||||
|
|
||||||
class InventoryParser(object):
|
class InventoryParser(object):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,579 +0,0 @@
|
||||||
"""Utilities for writing code that runs on Python 2 and 3"""
|
|
||||||
|
|
||||||
# Copyright (c) 2010-2013 Benjamin Peterson
|
|
||||||
#
|
|
||||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
# of this software and associated documentation files (the "Software"), to deal
|
|
||||||
# in the Software without restriction, including without limitation the rights
|
|
||||||
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
# copies of the Software, and to permit persons to whom the Software is
|
|
||||||
# furnished to do so, subject to the following conditions:
|
|
||||||
#
|
|
||||||
# The above copyright notice and this permission notice shall be included in all
|
|
||||||
# copies or substantial portions of the Software.
|
|
||||||
#
|
|
||||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
# SOFTWARE.
|
|
||||||
|
|
||||||
import operator
|
|
||||||
import sys
|
|
||||||
import types
|
|
||||||
|
|
||||||
__author__ = "Benjamin Peterson <benjamin@python.org>"
|
|
||||||
__version__ = "1.4.1"
|
|
||||||
|
|
||||||
|
|
||||||
# Useful for very coarse version differentiation.
|
|
||||||
PY2 = sys.version_info[0] == 2
|
|
||||||
PY3 = sys.version_info[0] == 3
|
|
||||||
|
|
||||||
if PY3:
|
|
||||||
string_types = str,
|
|
||||||
integer_types = int,
|
|
||||||
class_types = type,
|
|
||||||
text_type = str
|
|
||||||
binary_type = bytes
|
|
||||||
cmp = lambda a, b: (a > b) - (a < b)
|
|
||||||
|
|
||||||
MAXSIZE = sys.maxsize
|
|
||||||
else:
|
|
||||||
string_types = basestring,
|
|
||||||
integer_types = (int, long)
|
|
||||||
class_types = (type, types.ClassType)
|
|
||||||
text_type = unicode
|
|
||||||
binary_type = str
|
|
||||||
cmp = cmp
|
|
||||||
|
|
||||||
if sys.platform.startswith("java"):
|
|
||||||
# Jython always uses 32 bits.
|
|
||||||
MAXSIZE = int((1 << 31) - 1)
|
|
||||||
else:
|
|
||||||
# It's possible to have sizeof(long) != sizeof(Py_ssize_t).
|
|
||||||
class X(object):
|
|
||||||
def __len__(self):
|
|
||||||
return 1 << 31
|
|
||||||
try:
|
|
||||||
len(X())
|
|
||||||
except OverflowError:
|
|
||||||
# 32-bit
|
|
||||||
MAXSIZE = int((1 << 31) - 1)
|
|
||||||
else:
|
|
||||||
# 64-bit
|
|
||||||
MAXSIZE = int((1 << 63) - 1)
|
|
||||||
del X
|
|
||||||
|
|
||||||
|
|
||||||
def _add_doc(func, doc):
|
|
||||||
"""Add documentation to a function."""
|
|
||||||
func.__doc__ = doc
|
|
||||||
|
|
||||||
|
|
||||||
def _import_module(name):
|
|
||||||
"""Import module, returning the module after the last dot."""
|
|
||||||
__import__(name)
|
|
||||||
return sys.modules[name]
|
|
||||||
|
|
||||||
|
|
||||||
class _LazyDescr(object):
|
|
||||||
|
|
||||||
def __init__(self, name):
|
|
||||||
self.name = name
|
|
||||||
|
|
||||||
def __get__(self, obj, tp):
|
|
||||||
result = self._resolve()
|
|
||||||
setattr(obj, self.name, result)
|
|
||||||
# This is a bit ugly, but it avoids running this again.
|
|
||||||
delattr(tp, self.name)
|
|
||||||
return result
|
|
||||||
|
|
||||||
|
|
||||||
class MovedModule(_LazyDescr):
|
|
||||||
|
|
||||||
def __init__(self, name, old, new=None):
|
|
||||||
super(MovedModule, self).__init__(name)
|
|
||||||
if PY3:
|
|
||||||
if new is None:
|
|
||||||
new = name
|
|
||||||
self.mod = new
|
|
||||||
else:
|
|
||||||
self.mod = old
|
|
||||||
|
|
||||||
def _resolve(self):
|
|
||||||
return _import_module(self.mod)
|
|
||||||
|
|
||||||
|
|
||||||
class MovedAttribute(_LazyDescr):
|
|
||||||
|
|
||||||
def __init__(self, name, old_mod, new_mod, old_attr=None, new_attr=None):
|
|
||||||
super(MovedAttribute, self).__init__(name)
|
|
||||||
if PY3:
|
|
||||||
if new_mod is None:
|
|
||||||
new_mod = name
|
|
||||||
self.mod = new_mod
|
|
||||||
if new_attr is None:
|
|
||||||
if old_attr is None:
|
|
||||||
new_attr = name
|
|
||||||
else:
|
|
||||||
new_attr = old_attr
|
|
||||||
self.attr = new_attr
|
|
||||||
else:
|
|
||||||
self.mod = old_mod
|
|
||||||
if old_attr is None:
|
|
||||||
old_attr = name
|
|
||||||
self.attr = old_attr
|
|
||||||
|
|
||||||
def _resolve(self):
|
|
||||||
module = _import_module(self.mod)
|
|
||||||
return getattr(module, self.attr)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class _MovedItems(types.ModuleType):
|
|
||||||
"""Lazy loading of moved objects"""
|
|
||||||
|
|
||||||
|
|
||||||
_moved_attributes = [
|
|
||||||
MovedAttribute("cStringIO", "cStringIO", "io", "StringIO"),
|
|
||||||
MovedAttribute("filter", "itertools", "builtins", "ifilter", "filter"),
|
|
||||||
MovedAttribute("filterfalse", "itertools", "itertools", "ifilterfalse", "filterfalse"),
|
|
||||||
MovedAttribute("input", "__builtin__", "builtins", "raw_input", "input"),
|
|
||||||
MovedAttribute("map", "itertools", "builtins", "imap", "map"),
|
|
||||||
MovedAttribute("range", "__builtin__", "builtins", "xrange", "range"),
|
|
||||||
MovedAttribute("reload_module", "__builtin__", "imp", "reload"),
|
|
||||||
MovedAttribute("reduce", "__builtin__", "functools"),
|
|
||||||
MovedAttribute("StringIO", "StringIO", "io"),
|
|
||||||
MovedAttribute("UserString", "UserString", "collections"),
|
|
||||||
MovedAttribute("xrange", "__builtin__", "builtins", "xrange", "range"),
|
|
||||||
MovedAttribute("zip", "itertools", "builtins", "izip", "zip"),
|
|
||||||
MovedAttribute("zip_longest", "itertools", "itertools", "izip_longest", "zip_longest"),
|
|
||||||
|
|
||||||
MovedModule("builtins", "__builtin__"),
|
|
||||||
MovedModule("configparser", "ConfigParser"),
|
|
||||||
MovedModule("copyreg", "copy_reg"),
|
|
||||||
MovedModule("http_cookiejar", "cookielib", "http.cookiejar"),
|
|
||||||
MovedModule("http_cookies", "Cookie", "http.cookies"),
|
|
||||||
MovedModule("html_entities", "htmlentitydefs", "html.entities"),
|
|
||||||
MovedModule("html_parser", "HTMLParser", "html.parser"),
|
|
||||||
MovedModule("http_client", "httplib", "http.client"),
|
|
||||||
MovedModule("email_mime_multipart", "email.MIMEMultipart", "email.mime.multipart"),
|
|
||||||
MovedModule("email_mime_text", "email.MIMEText", "email.mime.text"),
|
|
||||||
MovedModule("email_mime_base", "email.MIMEBase", "email.mime.base"),
|
|
||||||
MovedModule("BaseHTTPServer", "BaseHTTPServer", "http.server"),
|
|
||||||
MovedModule("CGIHTTPServer", "CGIHTTPServer", "http.server"),
|
|
||||||
MovedModule("SimpleHTTPServer", "SimpleHTTPServer", "http.server"),
|
|
||||||
MovedModule("cPickle", "cPickle", "pickle"),
|
|
||||||
MovedModule("queue", "Queue"),
|
|
||||||
MovedModule("reprlib", "repr"),
|
|
||||||
MovedModule("socketserver", "SocketServer"),
|
|
||||||
MovedModule("tkinter", "Tkinter"),
|
|
||||||
MovedModule("tkinter_dialog", "Dialog", "tkinter.dialog"),
|
|
||||||
MovedModule("tkinter_filedialog", "FileDialog", "tkinter.filedialog"),
|
|
||||||
MovedModule("tkinter_scrolledtext", "ScrolledText", "tkinter.scrolledtext"),
|
|
||||||
MovedModule("tkinter_simpledialog", "SimpleDialog", "tkinter.simpledialog"),
|
|
||||||
MovedModule("tkinter_tix", "Tix", "tkinter.tix"),
|
|
||||||
MovedModule("tkinter_constants", "Tkconstants", "tkinter.constants"),
|
|
||||||
MovedModule("tkinter_dnd", "Tkdnd", "tkinter.dnd"),
|
|
||||||
MovedModule("tkinter_colorchooser", "tkColorChooser",
|
|
||||||
"tkinter.colorchooser"),
|
|
||||||
MovedModule("tkinter_commondialog", "tkCommonDialog",
|
|
||||||
"tkinter.commondialog"),
|
|
||||||
MovedModule("tkinter_tkfiledialog", "tkFileDialog", "tkinter.filedialog"),
|
|
||||||
MovedModule("tkinter_font", "tkFont", "tkinter.font"),
|
|
||||||
MovedModule("tkinter_messagebox", "tkMessageBox", "tkinter.messagebox"),
|
|
||||||
MovedModule("tkinter_tksimpledialog", "tkSimpleDialog",
|
|
||||||
"tkinter.simpledialog"),
|
|
||||||
MovedModule("urllib_parse", __name__ + ".moves.urllib_parse", "urllib.parse"),
|
|
||||||
MovedModule("urllib_error", __name__ + ".moves.urllib_error", "urllib.error"),
|
|
||||||
MovedModule("urllib", __name__ + ".moves.urllib", __name__ + ".moves.urllib"),
|
|
||||||
MovedModule("urllib_robotparser", "robotparser", "urllib.robotparser"),
|
|
||||||
MovedModule("winreg", "_winreg"),
|
|
||||||
]
|
|
||||||
for attr in _moved_attributes:
|
|
||||||
setattr(_MovedItems, attr.name, attr)
|
|
||||||
del attr
|
|
||||||
|
|
||||||
moves = sys.modules[__name__ + ".moves"] = _MovedItems(__name__ + ".moves")
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class Module_six_moves_urllib_parse(types.ModuleType):
|
|
||||||
"""Lazy loading of moved objects in six.moves.urllib_parse"""
|
|
||||||
|
|
||||||
|
|
||||||
_urllib_parse_moved_attributes = [
|
|
||||||
MovedAttribute("ParseResult", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("parse_qs", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("parse_qsl", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("urldefrag", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("urljoin", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("urlparse", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("urlsplit", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("urlunparse", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("urlunsplit", "urlparse", "urllib.parse"),
|
|
||||||
MovedAttribute("quote", "urllib", "urllib.parse"),
|
|
||||||
MovedAttribute("quote_plus", "urllib", "urllib.parse"),
|
|
||||||
MovedAttribute("unquote", "urllib", "urllib.parse"),
|
|
||||||
MovedAttribute("unquote_plus", "urllib", "urllib.parse"),
|
|
||||||
MovedAttribute("urlencode", "urllib", "urllib.parse"),
|
|
||||||
]
|
|
||||||
for attr in _urllib_parse_moved_attributes:
|
|
||||||
setattr(Module_six_moves_urllib_parse, attr.name, attr)
|
|
||||||
del attr
|
|
||||||
|
|
||||||
sys.modules[__name__ + ".moves.urllib_parse"] = Module_six_moves_urllib_parse(__name__ + ".moves.urllib_parse")
|
|
||||||
sys.modules[__name__ + ".moves.urllib.parse"] = Module_six_moves_urllib_parse(__name__ + ".moves.urllib.parse")
|
|
||||||
|
|
||||||
|
|
||||||
class Module_six_moves_urllib_error(types.ModuleType):
|
|
||||||
"""Lazy loading of moved objects in six.moves.urllib_error"""
|
|
||||||
|
|
||||||
|
|
||||||
_urllib_error_moved_attributes = [
|
|
||||||
MovedAttribute("URLError", "urllib2", "urllib.error"),
|
|
||||||
MovedAttribute("HTTPError", "urllib2", "urllib.error"),
|
|
||||||
MovedAttribute("ContentTooShortError", "urllib", "urllib.error"),
|
|
||||||
]
|
|
||||||
for attr in _urllib_error_moved_attributes:
|
|
||||||
setattr(Module_six_moves_urllib_error, attr.name, attr)
|
|
||||||
del attr
|
|
||||||
|
|
||||||
sys.modules[__name__ + ".moves.urllib_error"] = Module_six_moves_urllib_error(__name__ + ".moves.urllib_error")
|
|
||||||
sys.modules[__name__ + ".moves.urllib.error"] = Module_six_moves_urllib_error(__name__ + ".moves.urllib.error")
|
|
||||||
|
|
||||||
|
|
||||||
class Module_six_moves_urllib_request(types.ModuleType):
|
|
||||||
"""Lazy loading of moved objects in six.moves.urllib_request"""
|
|
||||||
|
|
||||||
|
|
||||||
_urllib_request_moved_attributes = [
|
|
||||||
MovedAttribute("urlopen", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("install_opener", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("build_opener", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("pathname2url", "urllib", "urllib.request"),
|
|
||||||
MovedAttribute("url2pathname", "urllib", "urllib.request"),
|
|
||||||
MovedAttribute("getproxies", "urllib", "urllib.request"),
|
|
||||||
MovedAttribute("Request", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("OpenerDirector", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPDefaultErrorHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPRedirectHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPCookieProcessor", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("ProxyHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("BaseHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPPasswordMgr", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPPasswordMgrWithDefaultRealm", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("AbstractBasicAuthHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPBasicAuthHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("ProxyBasicAuthHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("AbstractDigestAuthHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPDigestAuthHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("ProxyDigestAuthHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPSHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("FileHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("FTPHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("CacheFTPHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("UnknownHandler", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("HTTPErrorProcessor", "urllib2", "urllib.request"),
|
|
||||||
MovedAttribute("urlretrieve", "urllib", "urllib.request"),
|
|
||||||
MovedAttribute("urlcleanup", "urllib", "urllib.request"),
|
|
||||||
MovedAttribute("URLopener", "urllib", "urllib.request"),
|
|
||||||
MovedAttribute("FancyURLopener", "urllib", "urllib.request"),
|
|
||||||
]
|
|
||||||
for attr in _urllib_request_moved_attributes:
|
|
||||||
setattr(Module_six_moves_urllib_request, attr.name, attr)
|
|
||||||
del attr
|
|
||||||
|
|
||||||
sys.modules[__name__ + ".moves.urllib_request"] = Module_six_moves_urllib_request(__name__ + ".moves.urllib_request")
|
|
||||||
sys.modules[__name__ + ".moves.urllib.request"] = Module_six_moves_urllib_request(__name__ + ".moves.urllib.request")
|
|
||||||
|
|
||||||
|
|
||||||
class Module_six_moves_urllib_response(types.ModuleType):
|
|
||||||
"""Lazy loading of moved objects in six.moves.urllib_response"""
|
|
||||||
|
|
||||||
|
|
||||||
_urllib_response_moved_attributes = [
|
|
||||||
MovedAttribute("addbase", "urllib", "urllib.response"),
|
|
||||||
MovedAttribute("addclosehook", "urllib", "urllib.response"),
|
|
||||||
MovedAttribute("addinfo", "urllib", "urllib.response"),
|
|
||||||
MovedAttribute("addinfourl", "urllib", "urllib.response"),
|
|
||||||
]
|
|
||||||
for attr in _urllib_response_moved_attributes:
|
|
||||||
setattr(Module_six_moves_urllib_response, attr.name, attr)
|
|
||||||
del attr
|
|
||||||
|
|
||||||
sys.modules[__name__ + ".moves.urllib_response"] = Module_six_moves_urllib_response(__name__ + ".moves.urllib_response")
|
|
||||||
sys.modules[__name__ + ".moves.urllib.response"] = Module_six_moves_urllib_response(__name__ + ".moves.urllib.response")
|
|
||||||
|
|
||||||
|
|
||||||
class Module_six_moves_urllib_robotparser(types.ModuleType):
|
|
||||||
"""Lazy loading of moved objects in six.moves.urllib_robotparser"""
|
|
||||||
|
|
||||||
|
|
||||||
_urllib_robotparser_moved_attributes = [
|
|
||||||
MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"),
|
|
||||||
]
|
|
||||||
for attr in _urllib_robotparser_moved_attributes:
|
|
||||||
setattr(Module_six_moves_urllib_robotparser, attr.name, attr)
|
|
||||||
del attr
|
|
||||||
|
|
||||||
sys.modules[__name__ + ".moves.urllib_robotparser"] = Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib_robotparser")
|
|
||||||
sys.modules[__name__ + ".moves.urllib.robotparser"] = Module_six_moves_urllib_robotparser(__name__ + ".moves.urllib.robotparser")
|
|
||||||
|
|
||||||
|
|
||||||
class Module_six_moves_urllib(types.ModuleType):
|
|
||||||
"""Create a six.moves.urllib namespace that resembles the Python 3 namespace"""
|
|
||||||
parse = sys.modules[__name__ + ".moves.urllib_parse"]
|
|
||||||
error = sys.modules[__name__ + ".moves.urllib_error"]
|
|
||||||
request = sys.modules[__name__ + ".moves.urllib_request"]
|
|
||||||
response = sys.modules[__name__ + ".moves.urllib_response"]
|
|
||||||
robotparser = sys.modules[__name__ + ".moves.urllib_robotparser"]
|
|
||||||
|
|
||||||
|
|
||||||
sys.modules[__name__ + ".moves.urllib"] = Module_six_moves_urllib(__name__ + ".moves.urllib")
|
|
||||||
|
|
||||||
|
|
||||||
def add_move(move):
|
|
||||||
"""Add an item to six.moves."""
|
|
||||||
setattr(_MovedItems, move.name, move)
|
|
||||||
|
|
||||||
|
|
||||||
def remove_move(name):
|
|
||||||
"""Remove item from six.moves."""
|
|
||||||
try:
|
|
||||||
delattr(_MovedItems, name)
|
|
||||||
except AttributeError:
|
|
||||||
try:
|
|
||||||
del moves.__dict__[name]
|
|
||||||
except KeyError:
|
|
||||||
raise AttributeError("no such move, %r" % (name,))
|
|
||||||
|
|
||||||
|
|
||||||
if PY3:
|
|
||||||
_meth_func = "__func__"
|
|
||||||
_meth_self = "__self__"
|
|
||||||
|
|
||||||
_func_closure = "__closure__"
|
|
||||||
_func_code = "__code__"
|
|
||||||
_func_defaults = "__defaults__"
|
|
||||||
_func_globals = "__globals__"
|
|
||||||
|
|
||||||
_iterkeys = "keys"
|
|
||||||
_itervalues = "values"
|
|
||||||
_iteritems = "items"
|
|
||||||
_iterlists = "lists"
|
|
||||||
else:
|
|
||||||
_meth_func = "im_func"
|
|
||||||
_meth_self = "im_self"
|
|
||||||
|
|
||||||
_func_closure = "func_closure"
|
|
||||||
_func_code = "func_code"
|
|
||||||
_func_defaults = "func_defaults"
|
|
||||||
_func_globals = "func_globals"
|
|
||||||
|
|
||||||
_iterkeys = "iterkeys"
|
|
||||||
_itervalues = "itervalues"
|
|
||||||
_iteritems = "iteritems"
|
|
||||||
_iterlists = "iterlists"
|
|
||||||
|
|
||||||
|
|
||||||
try:
|
|
||||||
advance_iterator = next
|
|
||||||
except NameError:
|
|
||||||
def advance_iterator(it):
|
|
||||||
return it.next()
|
|
||||||
next = advance_iterator
|
|
||||||
|
|
||||||
|
|
||||||
try:
|
|
||||||
callable = callable
|
|
||||||
except NameError:
|
|
||||||
def callable(obj):
|
|
||||||
return any("__call__" in klass.__dict__ for klass in type(obj).__mro__)
|
|
||||||
|
|
||||||
|
|
||||||
if PY3:
|
|
||||||
def get_unbound_function(unbound):
|
|
||||||
return unbound
|
|
||||||
|
|
||||||
create_bound_method = types.MethodType
|
|
||||||
|
|
||||||
Iterator = object
|
|
||||||
else:
|
|
||||||
def get_unbound_function(unbound):
|
|
||||||
return unbound.im_func
|
|
||||||
|
|
||||||
def create_bound_method(func, obj):
|
|
||||||
return types.MethodType(func, obj, obj.__class__)
|
|
||||||
|
|
||||||
class Iterator(object):
|
|
||||||
|
|
||||||
def next(self):
|
|
||||||
return type(self).__next__(self)
|
|
||||||
|
|
||||||
callable = callable
|
|
||||||
_add_doc(get_unbound_function,
|
|
||||||
"""Get the function out of a possibly unbound function""")
|
|
||||||
|
|
||||||
|
|
||||||
get_method_function = operator.attrgetter(_meth_func)
|
|
||||||
get_method_self = operator.attrgetter(_meth_self)
|
|
||||||
get_function_closure = operator.attrgetter(_func_closure)
|
|
||||||
get_function_code = operator.attrgetter(_func_code)
|
|
||||||
get_function_defaults = operator.attrgetter(_func_defaults)
|
|
||||||
get_function_globals = operator.attrgetter(_func_globals)
|
|
||||||
|
|
||||||
|
|
||||||
def iterkeys(d, **kw):
|
|
||||||
"""Return an iterator over the keys of a dictionary."""
|
|
||||||
return iter(getattr(d, _iterkeys)(**kw))
|
|
||||||
|
|
||||||
def itervalues(d, **kw):
|
|
||||||
"""Return an iterator over the values of a dictionary."""
|
|
||||||
return iter(getattr(d, _itervalues)(**kw))
|
|
||||||
|
|
||||||
def iteritems(d, **kw):
|
|
||||||
"""Return an iterator over the (key, value) pairs of a dictionary."""
|
|
||||||
return iter(getattr(d, _iteritems)(**kw))
|
|
||||||
|
|
||||||
def iterlists(d, **kw):
|
|
||||||
"""Return an iterator over the (key, [values]) pairs of a dictionary."""
|
|
||||||
return iter(getattr(d, _iterlists)(**kw))
|
|
||||||
|
|
||||||
|
|
||||||
if PY3:
|
|
||||||
def b(s):
|
|
||||||
return s.encode("latin-1")
|
|
||||||
def u(s):
|
|
||||||
return s
|
|
||||||
unichr = chr
|
|
||||||
if sys.version_info[1] <= 1:
|
|
||||||
def int2byte(i):
|
|
||||||
return bytes((i,))
|
|
||||||
else:
|
|
||||||
# This is about 2x faster than the implementation above on 3.2+
|
|
||||||
int2byte = operator.methodcaller("to_bytes", 1, "big")
|
|
||||||
byte2int = operator.itemgetter(0)
|
|
||||||
indexbytes = operator.getitem
|
|
||||||
iterbytes = iter
|
|
||||||
import io
|
|
||||||
StringIO = io.StringIO
|
|
||||||
BytesIO = io.BytesIO
|
|
||||||
else:
|
|
||||||
def b(s):
|
|
||||||
return s
|
|
||||||
def u(s):
|
|
||||||
return unicode(s, "unicode_escape")
|
|
||||||
unichr = unichr
|
|
||||||
int2byte = chr
|
|
||||||
def byte2int(bs):
|
|
||||||
return ord(bs[0])
|
|
||||||
def indexbytes(buf, i):
|
|
||||||
return ord(buf[i])
|
|
||||||
def iterbytes(buf):
|
|
||||||
return (ord(byte) for byte in buf)
|
|
||||||
import StringIO
|
|
||||||
StringIO = BytesIO = StringIO.StringIO
|
|
||||||
_add_doc(b, """Byte literal""")
|
|
||||||
_add_doc(u, """Text literal""")
|
|
||||||
|
|
||||||
|
|
||||||
if PY3:
|
|
||||||
import builtins
|
|
||||||
exec_ = getattr(builtins, "exec")
|
|
||||||
|
|
||||||
|
|
||||||
def reraise(tp, value, tb=None):
|
|
||||||
if value.__traceback__ is not tb:
|
|
||||||
raise value.with_traceback(tb)
|
|
||||||
raise value
|
|
||||||
|
|
||||||
|
|
||||||
print_ = getattr(builtins, "print")
|
|
||||||
del builtins
|
|
||||||
|
|
||||||
else:
|
|
||||||
def exec_(_code_, _globs_=None, _locs_=None):
|
|
||||||
"""Execute code in a namespace."""
|
|
||||||
if _globs_ is None:
|
|
||||||
frame = sys._getframe(1)
|
|
||||||
_globs_ = frame.f_globals
|
|
||||||
if _locs_ is None:
|
|
||||||
_locs_ = frame.f_locals
|
|
||||||
del frame
|
|
||||||
elif _locs_ is None:
|
|
||||||
_locs_ = _globs_
|
|
||||||
exec("""exec _code_ in _globs_, _locs_""")
|
|
||||||
|
|
||||||
|
|
||||||
exec_("""def reraise(tp, value, tb=None):
|
|
||||||
raise tp, value, tb
|
|
||||||
""")
|
|
||||||
|
|
||||||
|
|
||||||
def print_(*args, **kwargs):
|
|
||||||
"""The new-style print function."""
|
|
||||||
fp = kwargs.pop("file", sys.stdout)
|
|
||||||
if fp is None:
|
|
||||||
return
|
|
||||||
def write(data):
|
|
||||||
if not isinstance(data, basestring):
|
|
||||||
data = str(data)
|
|
||||||
fp.write(data)
|
|
||||||
want_unicode = False
|
|
||||||
sep = kwargs.pop("sep", None)
|
|
||||||
if sep is not None:
|
|
||||||
if isinstance(sep, unicode):
|
|
||||||
want_unicode = True
|
|
||||||
elif not isinstance(sep, str):
|
|
||||||
raise TypeError("sep must be None or a string")
|
|
||||||
end = kwargs.pop("end", None)
|
|
||||||
if end is not None:
|
|
||||||
if isinstance(end, unicode):
|
|
||||||
want_unicode = True
|
|
||||||
elif not isinstance(end, str):
|
|
||||||
raise TypeError("end must be None or a string")
|
|
||||||
if kwargs:
|
|
||||||
raise TypeError("invalid keyword arguments to print()")
|
|
||||||
if not want_unicode:
|
|
||||||
for arg in args:
|
|
||||||
if isinstance(arg, unicode):
|
|
||||||
want_unicode = True
|
|
||||||
break
|
|
||||||
if want_unicode:
|
|
||||||
newline = unicode("\n")
|
|
||||||
space = unicode(" ")
|
|
||||||
else:
|
|
||||||
newline = "\n"
|
|
||||||
space = " "
|
|
||||||
if sep is None:
|
|
||||||
sep = space
|
|
||||||
if end is None:
|
|
||||||
end = newline
|
|
||||||
for i, arg in enumerate(args):
|
|
||||||
if i:
|
|
||||||
write(sep)
|
|
||||||
write(arg)
|
|
||||||
write(end)
|
|
||||||
|
|
||||||
_add_doc(reraise, """Reraise an exception.""")
|
|
||||||
|
|
||||||
|
|
||||||
def with_metaclass(meta, *bases):
|
|
||||||
"""Create a base class with a metaclass."""
|
|
||||||
return meta("NewBase", bases, {})
|
|
||||||
|
|
||||||
def add_metaclass(metaclass):
|
|
||||||
"""Class decorator for creating a class with a metaclass."""
|
|
||||||
def wrapper(cls):
|
|
||||||
orig_vars = cls.__dict__.copy()
|
|
||||||
orig_vars.pop('__dict__', None)
|
|
||||||
orig_vars.pop('__weakref__', None)
|
|
||||||
for slots_var in orig_vars.get('__slots__', ()):
|
|
||||||
orig_vars.pop(slots_var)
|
|
||||||
return metaclass(cls.__name__, cls.__bases__, orig_vars)
|
|
||||||
return wrapper
|
|
116
lib/ansible/module_utils/six/__init__.py
Normal file
116
lib/ansible/module_utils/six/__init__.py
Normal file
|
@ -0,0 +1,116 @@
|
||||||
|
# This code is part of Ansible, but is an independent component.
|
||||||
|
# This particular file snippet, and this file snippet only, is BSD licensed.
|
||||||
|
# Modules you write using this snippet, which is embedded dynamically by Ansible
|
||||||
|
# still belong to the author of the module, and may assign their own license
|
||||||
|
# to the complete work.
|
||||||
|
#
|
||||||
|
# Copyright (c) 2017, Toshio Kuratomi <tkuratomi@ansible.com>
|
||||||
|
#
|
||||||
|
# This code is based on code from Astropy and retains their 3-clause BSD license
|
||||||
|
# reproduced below:
|
||||||
|
#
|
||||||
|
# Copyright (c) 2011-2016, Astropy Developers
|
||||||
|
#
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# * Redistributions of source code must retain the above copyright notice, this
|
||||||
|
# list of conditions and the following disclaimer.
|
||||||
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
# this list of conditions and the following disclaimer in the documentation
|
||||||
|
# and/or other materials provided with the distribution.
|
||||||
|
# * Neither the name of the Astropy Team nor the names of its contributors may
|
||||||
|
# be used to endorse or promote products derived from this software without
|
||||||
|
# specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||||
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||||
|
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||||
|
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||||
|
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
# Astropy License: https://github.com/astropy/astropy/blob/cf3265e42a0db8e00bb90644db37c8150f5ac00c/licenses/LICENSE.rst
|
||||||
|
# Astropy Code: https://github.com/astropy/astropy/blob/cf3265e42a0db8e00bb90644db37c8150f5ac00c/astropy/extern/six.py
|
||||||
|
|
||||||
|
"""
|
||||||
|
Handle loading six package from system or from the bundled copy
|
||||||
|
"""
|
||||||
|
from __future__ import absolute_import
|
||||||
|
|
||||||
|
import imp as _imp
|
||||||
|
import sys as _sys
|
||||||
|
|
||||||
|
try:
|
||||||
|
from distutils.version import LooseVersion as _LooseVersion
|
||||||
|
except ImportError:
|
||||||
|
# Some platforms *cough*Solaris*cough* don't ship the whole stdlib
|
||||||
|
_LooseVersion = None
|
||||||
|
|
||||||
|
try:
|
||||||
|
import six as _system_six
|
||||||
|
except ImportError:
|
||||||
|
_system_six = None
|
||||||
|
|
||||||
|
from . import _six as _bundled_six
|
||||||
|
|
||||||
|
|
||||||
|
def _find_module(name, path=None):
|
||||||
|
"""Alternative to `imp.find_module` that can also search in subpackages"""
|
||||||
|
parts = name.split('.')
|
||||||
|
|
||||||
|
for part in parts:
|
||||||
|
if path is not None:
|
||||||
|
path = [path]
|
||||||
|
fh, path, descr = _imp.find_module(part, path)
|
||||||
|
return fh, path, descr
|
||||||
|
|
||||||
|
|
||||||
|
def _get_bundled_six_source():
|
||||||
|
# Special import loader (zipimport for instance)
|
||||||
|
found = False
|
||||||
|
for path in _sys.path:
|
||||||
|
importer = _sys.path_importer_cache.get(path)
|
||||||
|
if importer:
|
||||||
|
try:
|
||||||
|
found = importer.find_module('ansible/module_utils/six/_six')
|
||||||
|
except ImportError:
|
||||||
|
continue
|
||||||
|
if found:
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
raise ImportError("Could not find ansible.module_utils.six._six")
|
||||||
|
|
||||||
|
module_source = importer.get_source('ansible/module_utils/six/_six')
|
||||||
|
return module_source
|
||||||
|
|
||||||
|
|
||||||
|
def _get_six_source():
|
||||||
|
"""Import the newest version of the six library that's available"""
|
||||||
|
mod_info = None
|
||||||
|
try:
|
||||||
|
if _system_six and _LooseVersion and \
|
||||||
|
_LooseVersion(_system_six.__version__) >= _LooseVersion(_bundled_six.__version__):
|
||||||
|
mod_info = _find_module('six')
|
||||||
|
except:
|
||||||
|
# Any errors finding the system library, use our bundled lib instead
|
||||||
|
pass
|
||||||
|
|
||||||
|
if not mod_info:
|
||||||
|
try:
|
||||||
|
mod_info = _find_module('ansible.module_utils.six._six')
|
||||||
|
except ImportError:
|
||||||
|
# zipimport
|
||||||
|
module_source = _get_bundled_six_source()
|
||||||
|
return module_source
|
||||||
|
|
||||||
|
return mod_info[0].read()
|
||||||
|
|
||||||
|
source = _get_six_source()
|
||||||
|
exec(source)
|
|
@ -25,10 +25,10 @@ import json
|
||||||
import tempfile
|
import tempfile
|
||||||
from yaml import YAMLError
|
from yaml import YAMLError
|
||||||
|
|
||||||
from ansible.compat.six import text_type, string_types
|
|
||||||
from ansible.errors import AnsibleFileNotFound, AnsibleParserError
|
from ansible.errors import AnsibleFileNotFound, AnsibleParserError
|
||||||
from ansible.errors.yaml_strings import YAML_SYNTAX_ERROR
|
from ansible.errors.yaml_strings import YAML_SYNTAX_ERROR
|
||||||
from ansible.module_utils.basic import is_executable
|
from ansible.module_utils.basic import is_executable
|
||||||
|
from ansible.module_utils.six import text_type, string_types
|
||||||
from ansible.module_utils._text import to_bytes, to_native, to_text
|
from ansible.module_utils._text import to_bytes, to_native, to_text
|
||||||
from ansible.parsing.vault import VaultLib, b_HEADER, is_encrypted, is_encrypted_file
|
from ansible.parsing.vault import VaultLib, b_HEADER, is_encrypted, is_encrypted_file
|
||||||
from ansible.parsing.quoting import unquote
|
from ansible.parsing.quoting import unquote
|
||||||
|
@ -43,7 +43,7 @@ except ImportError:
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
class DataLoader():
|
class DataLoader:
|
||||||
|
|
||||||
'''
|
'''
|
||||||
The DataLoader class is used to load and parse YAML or JSON content,
|
The DataLoader class is used to load and parse YAML or JSON content,
|
||||||
|
|
|
@ -19,14 +19,15 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
|
|
||||||
from ansible.errors import AnsibleParserError,AnsibleError
|
from ansible.errors import AnsibleParserError,AnsibleError
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.plugins import module_loader
|
from ansible.plugins import module_loader
|
||||||
from ansible.parsing.splitter import parse_kv, split_args
|
from ansible.parsing.splitter import parse_kv, split_args
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
|
|
||||||
|
|
||||||
# For filtering out modules correctly below
|
# For filtering out modules correctly below
|
||||||
RAW_PARAM_MODULES = ([
|
RAW_PARAM_MODULES = ([
|
||||||
'command',
|
'command',
|
||||||
|
@ -43,6 +44,7 @@ RAW_PARAM_MODULES = ([
|
||||||
'meta',
|
'meta',
|
||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
class ModuleArgsParser:
|
class ModuleArgsParser:
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -62,9 +62,9 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
HAS_AES = False
|
HAS_AES = False
|
||||||
|
|
||||||
from ansible.compat.six import PY3, binary_type
|
|
||||||
from ansible.compat.six.moves import zip
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import PY3, binary_type
|
||||||
|
from ansible.module_utils.six.moves import zip
|
||||||
from ansible.module_utils._text import to_bytes, to_text
|
from ansible.module_utils._text import to_bytes, to_text
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -20,8 +20,8 @@ from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
import yaml
|
import yaml
|
||||||
from ansible.compat.six import PY3
|
|
||||||
|
|
||||||
|
from ansible.module_utils.six import PY3
|
||||||
from ansible.parsing.yaml.objects import AnsibleUnicode, AnsibleSequence, AnsibleMapping
|
from ansible.parsing.yaml.objects import AnsibleUnicode, AnsibleSequence, AnsibleMapping
|
||||||
from ansible.parsing.yaml.objects import AnsibleVaultEncryptedUnicode
|
from ansible.parsing.yaml.objects import AnsibleVaultEncryptedUnicode
|
||||||
from ansible.vars.hostvars import HostVars
|
from ansible.vars.hostvars import HostVars
|
||||||
|
|
|
@ -21,7 +21,7 @@ __metaclass__ = type
|
||||||
|
|
||||||
import yaml
|
import yaml
|
||||||
|
|
||||||
from ansible.compat.six import text_type
|
from ansible.module_utils.six import text_type
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ from functools import partial
|
||||||
|
|
||||||
from jinja2.exceptions import UndefinedError
|
from jinja2.exceptions import UndefinedError
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types, with_metaclass
|
from ansible.module_utils.six import iteritems, string_types, with_metaclass
|
||||||
from ansible.errors import AnsibleParserError, AnsibleUndefinedVariable
|
from ansible.errors import AnsibleParserError, AnsibleUndefinedVariable
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.playbook.attribute import Attribute, FieldAttribute
|
from ansible.playbook.attribute import Attribute, FieldAttribute
|
||||||
|
|
|
@ -25,12 +25,12 @@ import re
|
||||||
from jinja2.compiler import generate
|
from jinja2.compiler import generate
|
||||||
from jinja2.exceptions import UndefinedError
|
from jinja2.exceptions import UndefinedError
|
||||||
|
|
||||||
from ansible.compat.six import text_type
|
|
||||||
from ansible.errors import AnsibleError, AnsibleUndefinedVariable
|
from ansible.errors import AnsibleError, AnsibleUndefinedVariable
|
||||||
|
from ansible.module_utils.six import text_type
|
||||||
|
from ansible.module_utils._text import to_native
|
||||||
from ansible.playbook.attribute import FieldAttribute
|
from ansible.playbook.attribute import FieldAttribute
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
from ansible.template.safe_eval import safe_eval
|
from ansible.template.safe_eval import safe_eval
|
||||||
from ansible.module_utils._text import to_native
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -38,6 +38,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
DEFINED_REGEX = re.compile(r'(hostvars\[.+\]|[\w_]+)\s+(not\s+is|is|is\s+not)\s+(defined|undefined)')
|
DEFINED_REGEX = re.compile(r'(hostvars\[.+\]|[\w_]+)\s+(not\s+is|is|is\s+not)\s+(defined|undefined)')
|
||||||
LOOKUP_REGEX = re.compile(r'lookup\s*\(')
|
LOOKUP_REGEX = re.compile(r'lookup\s*\(')
|
||||||
VALID_VAR_REGEX = re.compile("^[_A-Za-z][_a-zA-Z0-9]*$")
|
VALID_VAR_REGEX = re.compile("^[_A-Za-z][_a-zA-Z0-9]*$")
|
||||||
|
|
|
@ -21,8 +21,8 @@ __metaclass__ = type
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleParserError, AnsibleUndefinedVariable, AnsibleFileNotFound
|
from ansible.errors import AnsibleParserError, AnsibleUndefinedVariable, AnsibleFileNotFound
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
|
|
@ -21,11 +21,12 @@ __metaclass__ = type
|
||||||
|
|
||||||
import itertools
|
import itertools
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.playbook.attribute import FieldAttribute
|
from ansible.playbook.attribute import FieldAttribute
|
||||||
from ansible.playbook.base import Base
|
from ansible.playbook.base import Base
|
||||||
|
|
||||||
|
|
||||||
class LoopControl(Base):
|
class LoopControl(Base):
|
||||||
|
|
||||||
_loop_var = FieldAttribute(isa='str')
|
_loop_var = FieldAttribute(isa='str')
|
||||||
|
|
|
@ -19,10 +19,10 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
|
|
||||||
from ansible.errors import AnsibleParserError
|
from ansible.errors import AnsibleParserError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
|
||||||
from ansible.playbook.attribute import FieldAttribute
|
from ansible.playbook.attribute import FieldAttribute
|
||||||
from ansible.playbook.base import Base
|
from ansible.playbook.base import Base
|
||||||
|
|
|
@ -27,14 +27,15 @@ import random
|
||||||
import re
|
import re
|
||||||
import string
|
import string
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
from ansible.playbook.attribute import FieldAttribute
|
from ansible.playbook.attribute import FieldAttribute
|
||||||
from ansible.playbook.base import Base
|
from ansible.playbook.base import Base
|
||||||
|
|
||||||
|
|
||||||
boolean = C.mk_boolean
|
boolean = C.mk_boolean
|
||||||
|
|
||||||
__all__ = ['PlayContext']
|
__all__ = ['PlayContext']
|
||||||
|
|
|
@ -21,8 +21,8 @@ __metaclass__ = type
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible.errors import AnsibleParserError, AnsibleError
|
from ansible.errors import AnsibleParserError, AnsibleError
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
from ansible.parsing.splitter import split_args, parse_kv
|
from ansible.parsing.splitter import split_args, parse_kv
|
||||||
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject, AnsibleMapping
|
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject, AnsibleMapping
|
||||||
from ansible.playbook.attribute import FieldAttribute
|
from ansible.playbook.attribute import FieldAttribute
|
||||||
|
@ -31,6 +31,7 @@ from ansible.playbook.conditional import Conditional
|
||||||
from ansible.playbook.taggable import Taggable
|
from ansible.playbook.taggable import Taggable
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
|
|
||||||
|
|
||||||
class PlaybookInclude(Base, Conditional, Taggable):
|
class PlaybookInclude(Base, Conditional, Taggable):
|
||||||
|
|
||||||
_name = FieldAttribute(isa='string')
|
_name = FieldAttribute(isa='string')
|
||||||
|
|
|
@ -22,8 +22,8 @@ __metaclass__ = type
|
||||||
import collections
|
import collections
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, binary_type, text_type
|
|
||||||
from ansible.errors import AnsibleError, AnsibleParserError
|
from ansible.errors import AnsibleError, AnsibleParserError
|
||||||
|
from ansible.module_utils.six import iteritems, binary_type, text_type
|
||||||
from ansible.playbook.attribute import FieldAttribute
|
from ansible.playbook.attribute import FieldAttribute
|
||||||
from ansible.playbook.base import Base
|
from ansible.playbook.base import Base
|
||||||
from ansible.playbook.become import Become
|
from ansible.playbook.become import Become
|
||||||
|
|
|
@ -19,12 +19,11 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject, AnsibleMapping
|
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject, AnsibleMapping
|
||||||
from ansible.playbook.attribute import Attribute, FieldAttribute
|
from ansible.playbook.attribute import Attribute, FieldAttribute
|
||||||
from ansible.playbook.base import Base
|
from ansible.playbook.base import Base
|
||||||
|
|
|
@ -19,11 +19,10 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible.errors import AnsibleError, AnsibleParserError
|
from ansible.errors import AnsibleError, AnsibleParserError
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject
|
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject
|
||||||
from ansible.playbook.attribute import Attribute, FieldAttribute
|
from ansible.playbook.attribute import Attribute, FieldAttribute
|
||||||
from ansible.playbook.role.definition import RoleDefinition
|
from ansible.playbook.role.definition import RoleDefinition
|
||||||
|
|
|
@ -21,9 +21,8 @@ __metaclass__ = type
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
|
|
||||||
from ansible.errors import AnsibleParserError, AnsibleError
|
from ansible.errors import AnsibleParserError, AnsibleError
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
from ansible.playbook.attribute import Attribute, FieldAttribute
|
from ansible.playbook.attribute import Attribute, FieldAttribute
|
||||||
from ansible.playbook.base import Base
|
from ansible.playbook.base import Base
|
||||||
from ansible.playbook.helpers import load_list_of_roles
|
from ansible.playbook.helpers import load_list_of_roles
|
||||||
|
|
|
@ -19,16 +19,16 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import shutil
|
import shutil
|
||||||
import subprocess
|
import subprocess
|
||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.playbook.role.definition import RoleDefinition
|
from ansible.playbook.role.definition import RoleDefinition
|
||||||
|
|
||||||
|
|
||||||
__all__ = ['RoleRequirement']
|
__all__ = ['RoleRequirement']
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -21,11 +21,12 @@ __metaclass__ = type
|
||||||
|
|
||||||
import itertools
|
import itertools
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.playbook.attribute import FieldAttribute
|
from ansible.playbook.attribute import FieldAttribute
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
|
|
||||||
|
|
||||||
class Taggable:
|
class Taggable:
|
||||||
|
|
||||||
untagged = frozenset(['untagged'])
|
untagged = frozenset(['untagged'])
|
||||||
|
|
|
@ -21,8 +21,8 @@ __metaclass__ = type
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
from ansible.errors import AnsibleError, AnsibleParserError
|
from ansible.errors import AnsibleError, AnsibleParserError
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
from ansible.module_utils._text import to_native
|
from ansible.module_utils._text import to_native
|
||||||
from ansible.parsing.mod_args import ModuleArgsParser
|
from ansible.parsing.mod_args import ModuleArgsParser
|
||||||
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject, AnsibleMapping, AnsibleUnicode
|
from ansible.parsing.yaml.objects import AnsibleBaseYAMLObject, AnsibleMapping, AnsibleUnicode
|
||||||
|
|
|
@ -30,12 +30,12 @@ import time
|
||||||
from abc import ABCMeta, abstractmethod
|
from abc import ABCMeta, abstractmethod
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import binary_type, string_types, text_type, iteritems, with_metaclass
|
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.errors import AnsibleError, AnsibleConnectionFailure
|
from ansible.errors import AnsibleError, AnsibleConnectionFailure
|
||||||
from ansible.executor.module_common import modify_module, build_windows_module_payload
|
from ansible.executor.module_common import modify_module, build_windows_module_payload
|
||||||
from ansible.module_utils._text import to_bytes, to_native, to_text
|
|
||||||
from ansible.module_utils.json_utils import _filter_non_json_lines
|
from ansible.module_utils.json_utils import _filter_non_json_lines
|
||||||
|
from ansible.module_utils.six import binary_type, string_types, text_type, iteritems, with_metaclass
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
|
from ansible.module_utils._text import to_bytes, to_native, to_text
|
||||||
from ansible.parsing.utils.jsonify import jsonify
|
from ansible.parsing.utils.jsonify import jsonify
|
||||||
from ansible.playbook.play_context import MAGIC_VARIABLE_MAPPING
|
from ansible.playbook.play_context import MAGIC_VARIABLE_MAPPING
|
||||||
from ansible.release import __version__
|
from ansible.release import __version__
|
||||||
|
|
|
@ -20,11 +20,10 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.plugins.action import ActionBase
|
from ansible.plugins.action import ActionBase
|
||||||
from ansible.parsing.utils.addresses import parse_address
|
from ansible.parsing.utils.addresses import parse_address
|
||||||
from ansible.errors import AnsibleError
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
|
|
@ -18,8 +18,8 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleUndefinedVariable
|
from ansible.errors import AnsibleUndefinedVariable
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.plugins.action import ActionBase
|
from ansible.plugins.action import ActionBase
|
||||||
|
|
||||||
|
|
|
@ -23,13 +23,13 @@ import os
|
||||||
import sys
|
import sys
|
||||||
import copy
|
import copy
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
||||||
|
from ansible.module_utils.eos import eos_argument_spec
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
|
from ansible.module_utils._text import to_bytes
|
||||||
|
from ansible.plugins import connection_loader
|
||||||
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
||||||
from ansible.utils.path import unfrackpath
|
from ansible.utils.path import unfrackpath
|
||||||
from ansible.plugins import connection_loader
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible.module_utils.eos import eos_argument_spec
|
|
||||||
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
|
||||||
from ansible.module_utils._text import to_bytes
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -37,6 +37,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(_ActionModule):
|
class ActionModule(_ActionModule):
|
||||||
|
|
||||||
def run(self, tmp=None, task_vars=None):
|
def run(self, tmp=None, task_vars=None):
|
||||||
|
|
|
@ -22,9 +22,10 @@ from os import path, walk
|
||||||
import re
|
import re
|
||||||
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.module_utils._text import to_native, to_text
|
from ansible.module_utils._text import to_native, to_text
|
||||||
from ansible.plugins.action import ActionBase
|
from ansible.plugins.action import ActionBase
|
||||||
from ansible.compat.six import string_types
|
|
||||||
|
|
||||||
class ActionModule(ActionBase):
|
class ActionModule(ActionBase):
|
||||||
|
|
||||||
|
|
|
@ -26,9 +26,9 @@ import copy
|
||||||
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
||||||
from ansible.utils.path import unfrackpath
|
from ansible.utils.path import unfrackpath
|
||||||
from ansible.plugins import connection_loader
|
from ansible.plugins import connection_loader
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible.module_utils.ios import ios_argument_spec
|
|
||||||
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
||||||
|
from ansible.module_utils.ios import ios_argument_spec
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -37,6 +37,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(_ActionModule):
|
class ActionModule(_ActionModule):
|
||||||
|
|
||||||
def run(self, tmp=None, task_vars=None):
|
def run(self, tmp=None, task_vars=None):
|
||||||
|
|
|
@ -23,13 +23,13 @@ import os
|
||||||
import sys
|
import sys
|
||||||
import copy
|
import copy
|
||||||
|
|
||||||
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
|
||||||
from ansible.module_utils._text import to_bytes
|
|
||||||
from ansible.utils.path import unfrackpath
|
|
||||||
from ansible.plugins import connection_loader
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible.module_utils.iosxr import iosxr_argument_spec
|
|
||||||
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
||||||
|
from ansible.module_utils.iosxr import iosxr_argument_spec
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
|
from ansible.module_utils._text import to_bytes
|
||||||
|
from ansible.plugins import connection_loader
|
||||||
|
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
||||||
|
from ansible.utils.path import unfrackpath
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
|
|
@ -23,12 +23,12 @@ import os
|
||||||
import sys
|
import sys
|
||||||
import copy
|
import copy
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
||||||
|
from ansible.module_utils.junos import junos_argument_spec
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
|
from ansible.plugins import connection_loader, module_loader
|
||||||
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
||||||
from ansible.utils.path import unfrackpath
|
from ansible.utils.path import unfrackpath
|
||||||
from ansible.plugins import connection_loader, module_loader
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible.module_utils.junos import junos_argument_spec
|
|
||||||
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -36,6 +36,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(_ActionModule):
|
class ActionModule(_ActionModule):
|
||||||
|
|
||||||
def run(self, tmp=None, task_vars=None):
|
def run(self, tmp=None, task_vars=None):
|
||||||
|
|
|
@ -26,9 +26,9 @@ import copy
|
||||||
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
||||||
from ansible.utils.path import unfrackpath
|
from ansible.utils.path import unfrackpath
|
||||||
from ansible.plugins import connection_loader
|
from ansible.plugins import connection_loader
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible.module_utils.nxos import nxos_argument_spec
|
|
||||||
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
||||||
|
from ansible.module_utils.nxos import nxos_argument_spec
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -37,6 +37,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(_ActionModule):
|
class ActionModule(_ActionModule):
|
||||||
|
|
||||||
def run(self, tmp=None, task_vars=None):
|
def run(self, tmp=None, task_vars=None):
|
||||||
|
|
|
@ -21,10 +21,11 @@ __metaclass__ = type
|
||||||
|
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.plugins.action import ActionBase
|
from ansible.plugins.action import ActionBase
|
||||||
from ansible.plugins.action.net_template import ActionModule as NetActionModule
|
from ansible.plugins.action.net_template import ActionModule as NetActionModule
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(NetActionModule, ActionBase):
|
class ActionModule(NetActionModule, ActionBase):
|
||||||
|
|
||||||
def run(self, tmp=None, task_vars=None):
|
def run(self, tmp=None, task_vars=None):
|
||||||
|
|
|
@ -18,12 +18,12 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
|
|
||||||
from ansible.constants import mk_boolean as boolean
|
from ansible.constants import mk_boolean as boolean
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
from ansible.plugins.action import ActionBase
|
from ansible.plugins.action import ActionBase
|
||||||
from ansible.utils.vars import isidentifier
|
from ansible.utils.vars import isidentifier
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(ActionBase):
|
class ActionModule(ActionBase):
|
||||||
|
|
||||||
TRANSFERS_FILES = False
|
TRANSFERS_FILES = False
|
||||||
|
|
|
@ -18,11 +18,12 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
from ansible.constants import mk_boolean as boolean
|
from ansible.constants import mk_boolean as boolean
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
from ansible.plugins.action import ActionBase
|
from ansible.plugins.action import ActionBase
|
||||||
from ansible.utils.vars import isidentifier
|
from ansible.utils.vars import isidentifier
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(ActionBase):
|
class ActionModule(ActionBase):
|
||||||
|
|
||||||
TRANSFERS_FILES = False
|
TRANSFERS_FILES = False
|
||||||
|
|
|
@ -23,10 +23,9 @@ import pwd
|
||||||
import time
|
import time
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.module_utils._text import to_bytes, to_native, to_text
|
from ansible.module_utils._text import to_bytes, to_native, to_text
|
||||||
from ansible.module_utils.pycompat24 import get_exception
|
|
||||||
from ansible.plugins.action import ActionBase
|
from ansible.plugins.action import ActionBase
|
||||||
from ansible.utils.hashing import checksum_s
|
from ansible.utils.hashing import checksum_s
|
||||||
|
|
||||||
|
@ -45,8 +44,8 @@ class ActionModule(ActionBase):
|
||||||
dest = os.path.join(dest, base)
|
dest = os.path.join(dest, base)
|
||||||
dest_stat = self._execute_remote_stat(dest, all_vars=all_vars, follow=False, tmp=tmp)
|
dest_stat = self._execute_remote_stat(dest, all_vars=all_vars, follow=False, tmp=tmp)
|
||||||
|
|
||||||
except AnsibleError:
|
except AnsibleError as e:
|
||||||
return dict(failed=True, msg=to_native(get_exception()))
|
return dict(failed=True, msg=to_native(e))
|
||||||
|
|
||||||
return dest_stat['checksum']
|
return dest_stat['checksum']
|
||||||
|
|
||||||
|
@ -72,9 +71,9 @@ class ActionModule(ActionBase):
|
||||||
else:
|
else:
|
||||||
try:
|
try:
|
||||||
source = self._find_needle('templates', source)
|
source = self._find_needle('templates', source)
|
||||||
except AnsibleError:
|
except AnsibleError as e:
|
||||||
result['failed'] = True
|
result['failed'] = True
|
||||||
result['msg'] = to_native(get_exception())
|
result['msg'] = to_native(e)
|
||||||
|
|
||||||
if 'failed' in result:
|
if 'failed' in result:
|
||||||
return result
|
return result
|
||||||
|
|
|
@ -26,10 +26,10 @@ import copy
|
||||||
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
from ansible.plugins.action.normal import ActionModule as _ActionModule
|
||||||
from ansible.utils.path import unfrackpath
|
from ansible.utils.path import unfrackpath
|
||||||
from ansible.plugins import connection_loader
|
from ansible.plugins import connection_loader
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from ansible.module_utils.vyos import vyos_argument_spec
|
|
||||||
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
from ansible.module_utils.basic import AnsibleFallbackNotFound
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
from ansible.module_utils.vyos import vyos_argument_spec
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -37,6 +37,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
class ActionModule(_ActionModule):
|
class ActionModule(_ActionModule):
|
||||||
|
|
||||||
def run(self, tmp=None, task_vars=None):
|
def run(self, tmp=None, task_vars=None):
|
||||||
|
|
5
lib/ansible/plugins/cache/__init__.py
vendored
5
lib/ansible/plugins/cache/__init__.py
vendored
|
@ -24,10 +24,10 @@ from abc import ABCMeta, abstractmethod
|
||||||
from collections import MutableMapping
|
from collections import MutableMapping
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import with_metaclass
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.plugins import cache_loader
|
from ansible.module_utils.six import with_metaclass
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
from ansible.plugins import cache_loader
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -36,7 +36,6 @@ except ImportError:
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class BaseCacheModule(with_metaclass(ABCMeta, object)):
|
class BaseCacheModule(with_metaclass(ABCMeta, object)):
|
||||||
|
|
||||||
# Backwards compat only. Just import the global display instead
|
# Backwards compat only. Just import the global display instead
|
||||||
|
|
|
@ -61,7 +61,6 @@ import random
|
||||||
import time
|
import time
|
||||||
import codecs
|
import codecs
|
||||||
import uuid
|
import uuid
|
||||||
from ansible.compat.six.moves import configparser
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import certifi
|
import certifi
|
||||||
|
@ -75,6 +74,7 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
HAS_FLATDICT = False
|
HAS_FLATDICT = False
|
||||||
|
|
||||||
|
from ansible.module_utils.six.moves import configparser
|
||||||
from ansible.plugins.callback import CallbackBase
|
from ansible.plugins.callback import CallbackBase
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@ import os
|
||||||
import smtplib
|
import smtplib
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
from ansible.plugins.callback import CallbackBase
|
from ansible.plugins.callback import CallbackBase
|
||||||
|
|
||||||
|
|
|
@ -27,12 +27,14 @@ import collections
|
||||||
import os
|
import os
|
||||||
import time
|
import time
|
||||||
|
|
||||||
|
from ansible.module_utils.six.moves import reduce
|
||||||
from ansible.plugins.callback import CallbackBase
|
from ansible.plugins.callback import CallbackBase
|
||||||
from ansible.compat.six.moves import reduce
|
|
||||||
|
|
||||||
# define start time
|
# define start time
|
||||||
t0 = tn = time.time()
|
t0 = tn = time.time()
|
||||||
|
|
||||||
|
|
||||||
def secondsToStr(t):
|
def secondsToStr(t):
|
||||||
# http://bytes.com/topic/python/answers/635958-handy-short-cut-formatting-elapsed-time-floating-point-seconds
|
# http://bytes.com/topic/python/answers/635958-handy-short-cut-formatting-elapsed-time-floating-point-seconds
|
||||||
rediv = lambda ll, b: list(divmod(ll[0], b)) + ll[1:]
|
rediv = lambda ll, b: list(divmod(ll[0], b)) + ll[1:]
|
||||||
|
|
|
@ -24,23 +24,21 @@ import gettext
|
||||||
import os
|
import os
|
||||||
import shlex
|
import shlex
|
||||||
from abc import ABCMeta, abstractmethod, abstractproperty
|
from abc import ABCMeta, abstractmethod, abstractproperty
|
||||||
|
|
||||||
from functools import wraps
|
from functools import wraps
|
||||||
from ansible.compat.six import with_metaclass
|
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types, with_metaclass
|
||||||
from ansible.module_utils._text import to_bytes, to_text
|
from ansible.module_utils._text import to_bytes, to_text
|
||||||
from ansible.plugins import shell_loader
|
from ansible.plugins import shell_loader
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
__all__ = ['ConnectionBase', 'ensure_connect']
|
__all__ = ['ConnectionBase', 'ensure_connect']
|
||||||
|
|
||||||
BUFSIZE = 65536
|
BUFSIZE = 65536
|
||||||
|
|
|
@ -26,9 +26,9 @@ import subprocess
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.module_utils.basic import is_executable
|
from ansible.module_utils.basic import is_executable
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
||||||
|
|
||||||
|
|
|
@ -33,8 +33,8 @@ import re
|
||||||
from distutils.version import LooseVersion
|
from distutils.version import LooseVersion
|
||||||
|
|
||||||
import ansible.constants as C
|
import ansible.constants as C
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.errors import AnsibleError, AnsibleFileNotFound
|
from ansible.errors import AnsibleError, AnsibleFileNotFound
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
||||||
|
|
||||||
|
|
|
@ -26,8 +26,8 @@ import os.path
|
||||||
import subprocess
|
import subprocess
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
||||||
|
|
||||||
|
|
|
@ -27,8 +27,8 @@ import subprocess
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
||||||
|
|
||||||
|
|
|
@ -38,8 +38,8 @@ import getpass
|
||||||
|
|
||||||
import ansible.constants as C
|
import ansible.constants as C
|
||||||
from ansible.compat import selectors
|
from ansible.compat import selectors
|
||||||
from ansible.compat.six import text_type, binary_type
|
|
||||||
from ansible.errors import AnsibleError, AnsibleFileNotFound
|
from ansible.errors import AnsibleError, AnsibleFileNotFound
|
||||||
|
from ansible.module_utils.six import text_type, binary_type
|
||||||
from ansible.module_utils._text import to_bytes, to_native, to_text
|
from ansible.module_utils._text import to_bytes, to_native, to_text
|
||||||
from ansible.plugins.connection import ConnectionBase
|
from ansible.plugins.connection import ConnectionBase
|
||||||
|
|
||||||
|
|
|
@ -37,11 +37,10 @@ import re
|
||||||
from termios import tcflush, TCIFLUSH
|
from termios import tcflush, TCIFLUSH
|
||||||
from binascii import hexlify
|
from binascii import hexlify
|
||||||
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six.moves import input
|
|
||||||
from ansible.errors import AnsibleError, AnsibleConnectionFailure, AnsibleFileNotFound
|
from ansible.errors import AnsibleError, AnsibleConnectionFailure, AnsibleFileNotFound
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
|
from ansible.module_utils.six.moves import input
|
||||||
from ansible.plugins.connection import ConnectionBase
|
from ansible.plugins.connection import ConnectionBase
|
||||||
from ansible.utils.path import makedirs_safe
|
from ansible.utils.path import makedirs_safe
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
|
|
@ -109,12 +109,12 @@ import time
|
||||||
|
|
||||||
from functools import wraps
|
from functools import wraps
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat import selectors
|
|
||||||
from ansible.compat.six import PY3, text_type, binary_type
|
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.errors import AnsibleError, AnsibleConnectionFailure, AnsibleFileNotFound
|
from ansible.errors import AnsibleError, AnsibleConnectionFailure, AnsibleFileNotFound
|
||||||
from ansible.errors import AnsibleOptionsError
|
from ansible.errors import AnsibleOptionsError
|
||||||
from ansible.module_utils.basic import BOOLEANS
|
from ansible.module_utils.basic import BOOLEANS
|
||||||
|
from ansible.compat import selectors
|
||||||
|
from ansible.module_utils.six import PY3, text_type, binary_type
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.module_utils._text import to_bytes, to_native, to_text
|
from ansible.module_utils._text import to_bytes, to_native, to_text
|
||||||
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
||||||
from ansible.utils.path import unfrackpath, makedirs_safe
|
from ansible.utils.path import unfrackpath, makedirs_safe
|
||||||
|
@ -127,6 +127,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
SSHPASS_AVAILABLE = None
|
SSHPASS_AVAILABLE = None
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -37,12 +37,11 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.compat.six.moves.urllib.parse import urlunsplit
|
|
||||||
from ansible.errors import AnsibleError, AnsibleConnectionFailure
|
from ansible.errors import AnsibleError, AnsibleConnectionFailure
|
||||||
from ansible.errors import AnsibleFileNotFound
|
from ansible.errors import AnsibleFileNotFound
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
from ansible.module_utils.six.moves.urllib.parse import urlunsplit
|
||||||
from ansible.module_utils._text import to_bytes, to_native, to_text
|
from ansible.module_utils._text import to_bytes, to_native, to_text
|
||||||
from ansible.module_utils.pycompat24 import get_exception
|
|
||||||
from ansible.plugins.connection import ConnectionBase
|
from ansible.plugins.connection import ConnectionBase
|
||||||
from ansible.plugins.shell.powershell import exec_wrapper, become_wrapper, leaf_exec
|
from ansible.plugins.shell.powershell import exec_wrapper, become_wrapper, leaf_exec
|
||||||
from ansible.utils.hashing import secure_hash
|
from ansible.utils.hashing import secure_hash
|
||||||
|
@ -52,14 +51,12 @@ try:
|
||||||
import winrm
|
import winrm
|
||||||
from winrm import Response
|
from winrm import Response
|
||||||
from winrm.protocol import Protocol
|
from winrm.protocol import Protocol
|
||||||
except ImportError:
|
except ImportError as e:
|
||||||
e = get_exception()
|
|
||||||
raise AnsibleError("winrm or requests is not installed: %s" % str(e))
|
raise AnsibleError("winrm or requests is not installed: %s" % str(e))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import xmltodict
|
import xmltodict
|
||||||
except ImportError:
|
except ImportError as e:
|
||||||
e = get_exception()
|
|
||||||
raise AnsibleError("xmltodict is not installed: %s" % str(e))
|
raise AnsibleError("xmltodict is not installed: %s" % str(e))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -28,10 +28,10 @@ import subprocess
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
from ansible.plugins.connection import ConnectionBase, BUFSIZE
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -19,21 +19,21 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
import sys
|
|
||||||
import base64
|
import base64
|
||||||
|
import crypt
|
||||||
|
import glob
|
||||||
|
import hashlib
|
||||||
import itertools
|
import itertools
|
||||||
import json
|
import json
|
||||||
import os.path
|
|
||||||
import ntpath
|
import ntpath
|
||||||
import glob
|
import os.path
|
||||||
import re
|
import re
|
||||||
import crypt
|
|
||||||
import hashlib
|
|
||||||
import string
|
import string
|
||||||
|
import sys
|
||||||
|
import uuid
|
||||||
|
from datetime import datetime
|
||||||
from functools import partial
|
from functools import partial
|
||||||
from random import Random, SystemRandom, shuffle
|
from random import Random, SystemRandom, shuffle
|
||||||
from datetime import datetime
|
|
||||||
import uuid
|
|
||||||
|
|
||||||
import yaml
|
import yaml
|
||||||
from jinja2.filters import environmentfilter, do_groupby as _do_groupby
|
from jinja2.filters import environmentfilter, do_groupby as _do_groupby
|
||||||
|
@ -45,9 +45,8 @@ except:
|
||||||
HAS_PASSLIB = False
|
HAS_PASSLIB = False
|
||||||
|
|
||||||
from ansible import errors
|
from ansible import errors
|
||||||
from ansible.compat.six import iteritems, string_types, integer_types
|
from ansible.module_utils.six import iteritems, string_types, integer_types
|
||||||
from ansible.compat.six.moves import reduce
|
from ansible.module_utils.six.moves import reduce, shlex_quote
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
from ansible.module_utils._text import to_bytes, to_text
|
from ansible.module_utils._text import to_bytes, to_text
|
||||||
from ansible.parsing.yaml.dumper import AnsibleDumper
|
from ansible.parsing.yaml.dumper import AnsibleDumper
|
||||||
from ansible.utils.hashing import md5s, checksum_s
|
from ansible.utils.hashing import md5s, checksum_s
|
||||||
|
@ -58,6 +57,7 @@ from ansible.vars.hostvars import HostVars
|
||||||
|
|
||||||
UUID_NAMESPACE_ANSIBLE = uuid.UUID('361E6D51-FAEC-444A-9079-341386DA8E2E')
|
UUID_NAMESPACE_ANSIBLE = uuid.UUID('361E6D51-FAEC-444A-9079-341386DA8E2E')
|
||||||
|
|
||||||
|
|
||||||
class AnsibleJSONEncoder(json.JSONEncoder):
|
class AnsibleJSONEncoder(json.JSONEncoder):
|
||||||
'''
|
'''
|
||||||
Simple encoder class to deal with JSON encoding of internal
|
Simple encoder class to deal with JSON encoding of internal
|
||||||
|
|
|
@ -21,7 +21,7 @@ __metaclass__ = type
|
||||||
|
|
||||||
from abc import ABCMeta, abstractmethod
|
from abc import ABCMeta, abstractmethod
|
||||||
|
|
||||||
from ansible.compat.six import with_metaclass
|
from ansible.module_utils.six import with_metaclass
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
|
|
@ -122,10 +122,11 @@ import os
|
||||||
|
|
||||||
from jinja2.exceptions import UndefinedError
|
from jinja2.exceptions import UndefinedError
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleFileNotFound, AnsibleLookupError, AnsibleUndefinedVariable
|
|
||||||
from ansible.plugins.lookup import LookupBase
|
|
||||||
from ansible.constants import mk_boolean as boolean
|
from ansible.constants import mk_boolean as boolean
|
||||||
|
from ansible.errors import AnsibleFileNotFound, AnsibleLookupError, AnsibleUndefinedVariable
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
from ansible.plugins.lookup import LookupBase
|
||||||
|
|
||||||
|
|
||||||
class LookupModule(LookupBase):
|
class LookupModule(LookupBase):
|
||||||
|
|
||||||
|
|
|
@ -17,11 +17,12 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.plugins.lookup import LookupBase
|
||||||
from ansible.utils.listify import listify_lookup_plugin_terms
|
from ansible.utils.listify import listify_lookup_plugin_terms
|
||||||
|
|
||||||
|
|
||||||
class LookupModule(LookupBase):
|
class LookupModule(LookupBase):
|
||||||
|
|
||||||
def _check_list_of_one_list(self, term):
|
def _check_list_of_one_list(self, term):
|
||||||
|
|
|
@ -21,10 +21,10 @@ from io import StringIO
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
|
|
||||||
from ansible.compat.six.moves import configparser
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.module_utils.six.moves import configparser
|
||||||
from ansible.module_utils._text import to_bytes, to_text
|
from ansible.module_utils._text import to_bytes, to_text
|
||||||
|
from ansible.plugins.lookup import LookupBase
|
||||||
|
|
||||||
|
|
||||||
def _parse_params(term):
|
def _parse_params(term):
|
||||||
|
|
|
@ -24,8 +24,8 @@ import string
|
||||||
import random
|
import random
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six import text_type
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import text_type
|
||||||
from ansible.module_utils._text import to_bytes, to_native, to_text
|
from ansible.module_utils._text import to_bytes, to_native, to_text
|
||||||
from ansible.parsing.splitter import parse_kv
|
from ansible.parsing.splitter import parse_kv
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.plugins.lookup import LookupBase
|
||||||
|
|
|
@ -19,11 +19,12 @@ __metaclass__ = type
|
||||||
|
|
||||||
from re import compile as re_compile, IGNORECASE
|
from re import compile as re_compile, IGNORECASE
|
||||||
|
|
||||||
from ansible.compat.six.moves import xrange
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six.moves import xrange
|
||||||
from ansible.parsing.splitter import parse_kv
|
from ansible.parsing.splitter import parse_kv
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.plugins.lookup import LookupBase
|
||||||
|
|
||||||
|
|
||||||
# shortcut format
|
# shortcut format
|
||||||
NUM = "(0?x?[0-9a-f]+)"
|
NUM = "(0?x?[0-9a-f]+)"
|
||||||
SHORTCUT = re_compile(
|
SHORTCUT = re_compile(
|
||||||
|
|
|
@ -17,11 +17,12 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
from ansible.constants import mk_boolean as boolean
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.plugins.lookup import LookupBase
|
||||||
from ansible.utils.listify import listify_lookup_plugin_terms
|
from ansible.utils.listify import listify_lookup_plugin_terms
|
||||||
from ansible.constants import mk_boolean as boolean
|
|
||||||
|
|
||||||
FLAGS = ('skip_missing',)
|
FLAGS = ('skip_missing',)
|
||||||
|
|
||||||
|
|
|
@ -17,11 +17,12 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six.moves import zip_longest
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six.moves import zip_longest
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.plugins.lookup import LookupBase
|
||||||
from ansible.utils.listify import listify_lookup_plugin_terms
|
from ansible.utils.listify import listify_lookup_plugin_terms
|
||||||
|
|
||||||
|
|
||||||
class LookupModule(LookupBase):
|
class LookupModule(LookupBase):
|
||||||
"""
|
"""
|
||||||
Transpose a list of arrays:
|
Transpose a list of arrays:
|
||||||
|
|
|
@ -18,8 +18,8 @@ from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
|
|
||||||
from ansible.compat.six.moves.urllib.error import HTTPError, URLError
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.module_utils.six.moves.urllib.error import HTTPError, URLError
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.module_utils.urls import open_url, ConnectionError, SSLValidationError
|
from ansible.module_utils.urls import open_url, ConnectionError, SSLValidationError
|
||||||
from ansible.plugins.lookup import LookupBase
|
from ansible.plugins.lookup import LookupBase
|
||||||
|
|
|
@ -23,8 +23,8 @@ import ansible.constants as C
|
||||||
import time
|
import time
|
||||||
import random
|
import random
|
||||||
|
|
||||||
from ansible.compat.six import text_type
|
from ansible.module_utils.six import text_type
|
||||||
from ansible.compat.six.moves import shlex_quote
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
|
|
||||||
_USER_HOME_PATH_RE = re.compile(r'^~[_.A-Za-z0-9][-_.A-Za-z0-9]*$')
|
_USER_HOME_PATH_RE = re.compile(r'^~[_.A-Za-z0-9][-_.A-Za-z0-9]*$')
|
||||||
|
|
||||||
|
|
|
@ -17,9 +17,9 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
|
from ansible.module_utils.six import text_type
|
||||||
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.plugins.shell.sh import ShellModule as ShModule
|
from ansible.plugins.shell.sh import ShellModule as ShModule
|
||||||
from ansible.compat.six import text_type
|
|
||||||
from ansible.compat.six.moves import shlex_quote
|
|
||||||
|
|
||||||
|
|
||||||
class ShellModule(ShModule):
|
class ShellModule(ShModule):
|
||||||
|
|
|
@ -18,7 +18,7 @@ from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
|
|
||||||
from ansible.compat.six.moves import shlex_quote
|
from ansible.module_utils.six.moves import shlex_quote
|
||||||
from ansible.plugins.shell import ShellBase
|
from ansible.plugins.shell import ShellBase
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -27,14 +27,15 @@ from multiprocessing import Lock
|
||||||
from jinja2.exceptions import UndefinedError
|
from jinja2.exceptions import UndefinedError
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.compat.six.moves import queue as Queue
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
|
||||||
from ansible.errors import AnsibleError, AnsibleParserError, AnsibleUndefinedVariable
|
from ansible.errors import AnsibleError, AnsibleParserError, AnsibleUndefinedVariable
|
||||||
from ansible.executor import action_write_locks
|
from ansible.executor import action_write_locks
|
||||||
from ansible.executor.process.worker import WorkerProcess
|
from ansible.executor.process.worker import WorkerProcess
|
||||||
from ansible.executor.task_result import TaskResult
|
from ansible.executor.task_result import TaskResult
|
||||||
from ansible.inventory.host import Host
|
from ansible.inventory.host import Host
|
||||||
from ansible.inventory.group import Group
|
from ansible.inventory.group import Group
|
||||||
|
from ansible.module_utils.six.moves import queue as Queue
|
||||||
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.playbook.helpers import load_list_of_blocks
|
from ansible.playbook.helpers import load_list_of_blocks
|
||||||
from ansible.playbook.included_file import IncludedFile
|
from ansible.playbook.included_file import IncludedFile
|
||||||
from ansible.playbook.task_include import TaskInclude
|
from ansible.playbook.task_include import TaskInclude
|
||||||
|
@ -42,7 +43,6 @@ from ansible.playbook.role_include import IncludeRole
|
||||||
from ansible.plugins import action_loader, connection_loader, filter_loader, lookup_loader, module_loader, test_loader
|
from ansible.plugins import action_loader, connection_loader, filter_loader, lookup_loader, module_loader, test_loader
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
from ansible.vars import combine_vars, strip_internal_keys
|
from ansible.vars import combine_vars, strip_internal_keys
|
||||||
from ansible.module_utils._text import to_text
|
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -29,8 +29,8 @@ import cmd
|
||||||
import pprint
|
import pprint
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
from ansible.module_utils.six.moves import reduce
|
||||||
from ansible.plugins.strategy.linear import StrategyModule as LinearStrategyModule
|
from ansible.plugins.strategy.linear import StrategyModule as LinearStrategyModule
|
||||||
from ansible.compat.six.moves import reduce
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
|
|
@ -31,17 +31,16 @@ DOCUMENTATION:
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
|
|
||||||
from ansible.errors import AnsibleError
|
from ansible.errors import AnsibleError
|
||||||
from ansible.executor.play_iterator import PlayIterator
|
from ansible.executor.play_iterator import PlayIterator
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
|
from ansible.module_utils._text import to_text
|
||||||
from ansible.playbook.block import Block
|
from ansible.playbook.block import Block
|
||||||
from ansible.playbook.included_file import IncludedFile
|
from ansible.playbook.included_file import IncludedFile
|
||||||
from ansible.playbook.task import Task
|
from ansible.playbook.task import Task
|
||||||
from ansible.plugins import action_loader
|
from ansible.plugins import action_loader
|
||||||
from ansible.plugins.strategy import StrategyBase
|
from ansible.plugins.strategy import StrategyBase
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
from ansible.module_utils._text import to_text
|
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -23,8 +23,8 @@ import re
|
||||||
|
|
||||||
from abc import ABCMeta, abstractmethod
|
from abc import ABCMeta, abstractmethod
|
||||||
|
|
||||||
from ansible.compat.six import with_metaclass
|
|
||||||
from ansible.errors import AnsibleConnectionFailure
|
from ansible.errors import AnsibleConnectionFailure
|
||||||
|
from ansible.module_utils.six import with_metaclass
|
||||||
|
|
||||||
|
|
||||||
class TerminalBase(with_metaclass(ABCMeta, object)):
|
class TerminalBase(with_metaclass(ABCMeta, object)):
|
||||||
|
|
|
@ -27,25 +27,25 @@ import re
|
||||||
from io import StringIO
|
from io import StringIO
|
||||||
from numbers import Number
|
from numbers import Number
|
||||||
|
|
||||||
from jinja2 import Environment
|
|
||||||
from jinja2.loaders import FileSystemLoader
|
|
||||||
from jinja2.exceptions import TemplateSyntaxError, UndefinedError
|
|
||||||
from jinja2.utils import concat as j2_concat, missing
|
|
||||||
from jinja2.runtime import Context, StrictUndefined
|
|
||||||
from ansible import constants as C
|
|
||||||
from ansible.compat.six import string_types, text_type
|
|
||||||
from ansible.errors import AnsibleError, AnsibleFilterError, AnsibleUndefinedVariable
|
|
||||||
from ansible.plugins import filter_loader, lookup_loader, test_loader
|
|
||||||
from ansible.template.safe_eval import safe_eval
|
|
||||||
from ansible.template.template import AnsibleJ2Template
|
|
||||||
from ansible.template.vars import AnsibleJ2Vars
|
|
||||||
from ansible.module_utils._text import to_native, to_text
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from hashlib import sha1
|
from hashlib import sha1
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from sha import sha as sha1
|
from sha import sha as sha1
|
||||||
|
|
||||||
|
from jinja2 import Environment
|
||||||
|
from jinja2.loaders import FileSystemLoader
|
||||||
|
from jinja2.exceptions import TemplateSyntaxError, UndefinedError
|
||||||
|
from jinja2.utils import concat as j2_concat, missing
|
||||||
|
from jinja2.runtime import Context, StrictUndefined
|
||||||
|
|
||||||
|
from ansible import constants as C
|
||||||
|
from ansible.errors import AnsibleError, AnsibleFilterError, AnsibleUndefinedVariable
|
||||||
|
from ansible.module_utils.six import string_types, text_type
|
||||||
|
from ansible.module_utils._text import to_native, to_text
|
||||||
|
from ansible.plugins import filter_loader, lookup_loader, test_loader
|
||||||
|
from ansible.template.safe_eval import safe_eval
|
||||||
|
from ansible.template.template import AnsibleJ2Template
|
||||||
|
from ansible.template.vars import AnsibleJ2Vars
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from __main__ import display
|
from __main__ import display
|
||||||
|
@ -53,6 +53,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
__all__ = ['Templar']
|
__all__ = ['Templar']
|
||||||
|
|
||||||
# A regex for checking to see if a variable we're trying to
|
# A regex for checking to see if a variable we're trying to
|
||||||
|
|
|
@ -20,12 +20,12 @@ __metaclass__ = type
|
||||||
import ast
|
import ast
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
|
||||||
from ansible.compat.six.moves import builtins
|
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
|
from ansible.module_utils.six import string_types
|
||||||
|
from ansible.module_utils.six.moves import builtins
|
||||||
from ansible.plugins import filter_loader, test_loader
|
from ansible.plugins import filter_loader, test_loader
|
||||||
|
|
||||||
|
|
||||||
def safe_eval(expr, locals={}, include_exceptions=False):
|
def safe_eval(expr, locals={}, include_exceptions=False):
|
||||||
'''
|
'''
|
||||||
This is intended for allowing things like:
|
This is intended for allowing things like:
|
||||||
|
|
|
@ -19,8 +19,9 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from jinja2.utils import missing
|
from jinja2.utils import missing
|
||||||
|
|
||||||
|
from ansible.module_utils.six import iteritems
|
||||||
from ansible.module_utils._text import to_native
|
from ansible.module_utils._text import to_native
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -24,9 +24,10 @@ import shlex
|
||||||
import subprocess
|
import subprocess
|
||||||
import select
|
import select
|
||||||
|
|
||||||
from ansible.compat.six import PY2, PY3
|
from ansible.module_utils.six import PY2, PY3
|
||||||
from ansible.module_utils._text import to_bytes
|
from ansible.module_utils._text import to_bytes
|
||||||
|
|
||||||
|
|
||||||
def run_cmd(cmd, live=False, readsize=10):
|
def run_cmd(cmd, live=False, readsize=10):
|
||||||
|
|
||||||
#readsize = 10
|
#readsize = 10
|
||||||
|
|
|
@ -19,7 +19,8 @@
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
from ansible.module_utils.six import string_types
|
||||||
|
|
||||||
|
|
||||||
def pct_to_int(value, num_items, min_value=1):
|
def pct_to_int(value, num_items, min_value=1):
|
||||||
'''
|
'''
|
||||||
|
|
|
@ -21,13 +21,14 @@ __metaclass__ = type
|
||||||
|
|
||||||
from collections import Iterable
|
from collections import Iterable
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
from ansible.module_utils.six import string_types
|
||||||
|
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
from ansible.template.safe_eval import safe_eval
|
from ansible.template.safe_eval import safe_eval
|
||||||
|
|
||||||
|
|
||||||
__all__ = ['listify_lookup_plugin_terms']
|
__all__ = ['listify_lookup_plugin_terms']
|
||||||
|
|
||||||
|
|
||||||
def listify_lookup_plugin_terms(terms, templar, loader, fail_on_undefined=True, convert_bare=False):
|
def listify_lookup_plugin_terms(terms, templar, loader, fail_on_undefined=True, convert_bare=False):
|
||||||
|
|
||||||
if isinstance(terms, string_types):
|
if isinstance(terms, string_types):
|
||||||
|
|
|
@ -25,7 +25,7 @@ import yaml
|
||||||
|
|
||||||
from collections import MutableMapping, MutableSet, MutableSequence
|
from collections import MutableMapping, MutableSet, MutableSequence
|
||||||
|
|
||||||
from ansible.compat.six import string_types
|
from ansible.module_utils.six import string_types
|
||||||
from ansible.parsing.yaml.loader import AnsibleLoader
|
from ansible.parsing.yaml.loader import AnsibleLoader
|
||||||
from ansible.plugins import fragment_loader
|
from ansible.plugins import fragment_loader
|
||||||
|
|
||||||
|
@ -35,6 +35,7 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
|
|
||||||
# modules that are ok that they do not have documentation strings
|
# modules that are ok that they do not have documentation strings
|
||||||
BLACKLIST = {
|
BLACKLIST = {
|
||||||
'MODULE': frozenset(('async_wrapper',)),
|
'MODULE': frozenset(('async_wrapper',)),
|
||||||
|
|
|
@ -20,7 +20,7 @@ from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
import shlex
|
import shlex
|
||||||
from ansible.compat.six import PY3
|
from ansible.module_utils.six import PY3
|
||||||
from ansible.module_utils._text import to_bytes, to_text
|
from ansible.module_utils._text import to_bytes, to_text
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -26,18 +26,20 @@ import uuid
|
||||||
from json import dumps
|
from json import dumps
|
||||||
from collections import MutableMapping
|
from collections import MutableMapping
|
||||||
|
|
||||||
from ansible.compat.six import iteritems, string_types
|
from ansible.module_utils.six import iteritems, string_types
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.errors import AnsibleError, AnsibleOptionsError
|
from ansible.errors import AnsibleError, AnsibleOptionsError
|
||||||
from ansible.parsing.splitter import parse_kv
|
from ansible.parsing.splitter import parse_kv
|
||||||
from ansible.module_utils._text import to_native, to_text
|
from ansible.module_utils._text import to_native, to_text
|
||||||
|
|
||||||
|
|
||||||
_MAXSIZE = 2**32
|
_MAXSIZE = 2**32
|
||||||
cur_id = 0
|
cur_id = 0
|
||||||
node_mac = ("%012x" % uuid.getnode())[:12]
|
node_mac = ("%012x" % uuid.getnode())[:12]
|
||||||
random_int = ("%08x" % random.randint(0, _MAXSIZE))[:8]
|
random_int = ("%08x" % random.randint(0, _MAXSIZE))[:8]
|
||||||
|
|
||||||
|
|
||||||
def get_unique_id():
|
def get_unique_id():
|
||||||
global cur_id
|
global cur_id
|
||||||
cur_id += 1
|
cur_id += 1
|
||||||
|
|
|
@ -24,19 +24,18 @@ import sys
|
||||||
|
|
||||||
from collections import defaultdict, MutableMapping
|
from collections import defaultdict, MutableMapping
|
||||||
|
|
||||||
from ansible.compat.six import iteritems
|
|
||||||
from jinja2.exceptions import UndefinedError
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from hashlib import sha1
|
from hashlib import sha1
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from sha import sha as sha1
|
from sha import sha as sha1
|
||||||
|
|
||||||
|
from jinja2.exceptions import UndefinedError
|
||||||
|
|
||||||
from ansible import constants as C
|
from ansible import constants as C
|
||||||
from ansible.cli import CLI
|
from ansible.cli import CLI
|
||||||
from ansible.compat.six import string_types, text_type
|
|
||||||
from ansible.errors import AnsibleError, AnsibleParserError, AnsibleUndefinedVariable, AnsibleFileNotFound
|
from ansible.errors import AnsibleError, AnsibleParserError, AnsibleUndefinedVariable, AnsibleFileNotFound
|
||||||
from ansible.inventory.host import Host
|
from ansible.inventory.host import Host
|
||||||
|
from ansible.module_utils.six import iteritems, string_types, text_type
|
||||||
from ansible.plugins import lookup_loader
|
from ansible.plugins import lookup_loader
|
||||||
from ansible.plugins.cache import FactCache
|
from ansible.plugins.cache import FactCache
|
||||||
from ansible.template import Templar
|
from ansible.template import Templar
|
||||||
|
@ -51,14 +50,17 @@ except ImportError:
|
||||||
from ansible.utils.display import Display
|
from ansible.utils.display import Display
|
||||||
display = Display()
|
display = Display()
|
||||||
|
|
||||||
VARIABLE_CACHE = dict()
|
|
||||||
HOSTVARS_CACHE = dict()
|
VARIABLE_CACHE = {}
|
||||||
|
HOSTVARS_CACHE = {}
|
||||||
|
|
||||||
|
|
||||||
class AnsibleInventoryVarsData(dict):
|
class AnsibleInventoryVarsData(dict):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(AnsibleInventoryVarsData, self).__init__(*args, **kwargs)
|
super(AnsibleInventoryVarsData, self).__init__(*args, **kwargs)
|
||||||
self.path = None
|
self.path = None
|
||||||
|
|
||||||
|
|
||||||
def preprocess_vars(a):
|
def preprocess_vars(a):
|
||||||
'''
|
'''
|
||||||
Ensures that vars contained in the parameter passed in are
|
Ensures that vars contained in the parameter passed in are
|
||||||
|
|
|
@ -54,7 +54,7 @@ from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
import json
|
import json
|
||||||
from ansible.compat.six import string_types, text_type
|
from ansible.module_utils.six import string_types, text_type
|
||||||
from ansible.module_utils._text import to_text
|
from ansible.module_utils._text import to_text
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@ future1=$(find ./bin -type f -exec grep -HL 'from __future__ import (absolute_im
|
||||||
metaclass2=$(find ./lib/ansible -path ./lib/ansible/modules -prune \
|
metaclass2=$(find ./lib/ansible -path ./lib/ansible/modules -prune \
|
||||||
-o -path ./lib/ansible/modules/__init__.py \
|
-o -path ./lib/ansible/modules/__init__.py \
|
||||||
-o -path ./lib/ansible/module_utils -prune \
|
-o -path ./lib/ansible/module_utils -prune \
|
||||||
-o -path ./lib/ansible/compat/six/_six.py -prune \
|
-o -path ./lib/ansible/module_utils/six/_six.py -prune \
|
||||||
-o -path ./lib/ansible/compat/selectors/_selectors2.py -prune \
|
-o -path ./lib/ansible/compat/selectors/_selectors2.py -prune \
|
||||||
-o -path ./lib/ansible/utils/module_docs_fragments -prune \
|
-o -path ./lib/ansible/utils/module_docs_fragments -prune \
|
||||||
-o -name '*.py' -exec grep -HL '__metaclass__ = type' '{}' '+')
|
-o -name '*.py' -exec grep -HL '__metaclass__ = type' '{}' '+')
|
||||||
|
@ -14,7 +14,7 @@ metaclass2=$(find ./lib/ansible -path ./lib/ansible/modules -prune \
|
||||||
future2=$(find ./lib/ansible -path ./lib/ansible/modules -prune \
|
future2=$(find ./lib/ansible -path ./lib/ansible/modules -prune \
|
||||||
-o -path ./lib/ansible/modules/__init__.py \
|
-o -path ./lib/ansible/modules/__init__.py \
|
||||||
-o -path ./lib/ansible/module_utils -prune \
|
-o -path ./lib/ansible/module_utils -prune \
|
||||||
-o -path ./lib/ansible/compat/six/_six.py -prune \
|
-o -path ./lib/ansible/module_utils/six/_six.py -prune \
|
||||||
-o -path ./lib/ansible/compat/selectors/_selectors2.py -prune \
|
-o -path ./lib/ansible/compat/selectors/_selectors2.py -prune \
|
||||||
-o -path ./lib/ansible/utils/module_docs_fragments -prune \
|
-o -path ./lib/ansible/utils/module_docs_fragments -prune \
|
||||||
-o -name '*.py' -exec grep -HL 'from __future__ import (absolute_import, division, print_function)' '{}' '+')
|
-o -name '*.py' -exec grep -HL 'from __future__ import (absolute_import, division, print_function)' '{}' '+')
|
||||||
|
|
|
@ -6,8 +6,7 @@ BASESTRING_USERS=$(grep -r basestring . \
|
||||||
| grep isinstance \
|
| grep isinstance \
|
||||||
| grep -v \
|
| grep -v \
|
||||||
-e test/results/ \
|
-e test/results/ \
|
||||||
-e lib/ansible/compat/six/_six.py \
|
-e lib/ansible/module_utils/six/_six.py \
|
||||||
-e lib/ansible/module_utils/six.py \
|
|
||||||
-e lib/ansible/modules/ \
|
-e lib/ansible/modules/ \
|
||||||
-e '^[^:]*:#'
|
-e '^[^:]*:#'
|
||||||
)
|
)
|
||||||
|
|
|
@ -6,8 +6,7 @@ ITERITEMS_USERS=$(grep -rI '\.iteritems' . \
|
||||||
--exclude-dir docsite \
|
--exclude-dir docsite \
|
||||||
| grep -v \
|
| grep -v \
|
||||||
-e 'six\.iteritems' \
|
-e 'six\.iteritems' \
|
||||||
-e lib/ansible/compat/six/_six.py \
|
-e lib/ansible/module_utils/six/_six.py \
|
||||||
-e lib/ansible/module_utils/six.py \
|
|
||||||
-e test/sanity/code-smell/no-dict-iteritems.sh \
|
-e test/sanity/code-smell/no-dict-iteritems.sh \
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -15,7 +14,6 @@ if [ "${ITERITEMS_USERS}" ]; then
|
||||||
echo 'iteritems has been removed in python3. Alternatives:'
|
echo 'iteritems has been removed in python3. Alternatives:'
|
||||||
echo ' for KEY, VALUE in DICT.items():'
|
echo ' for KEY, VALUE in DICT.items():'
|
||||||
echo ' from ansible.module_utils.six import iteritems ; for KEY, VALUE in iteritems(DICT):'
|
echo ' from ansible.module_utils.six import iteritems ; for KEY, VALUE in iteritems(DICT):'
|
||||||
echo ' from ansible.compat.six import iteritems ; for KEY, VALUE in iteritems(DICT):'
|
|
||||||
echo "${ITERITEMS_USERS}"
|
echo "${ITERITEMS_USERS}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -6,8 +6,7 @@ ITERVALUES_USERS=$(grep -rI '\.itervalues' . \
|
||||||
--exclude-dir docsite \
|
--exclude-dir docsite \
|
||||||
| grep -v \
|
| grep -v \
|
||||||
-e 'six\.itervalues' \
|
-e 'six\.itervalues' \
|
||||||
-e lib/ansible/compat/six/_six.py \
|
-e lib/ansible/module_utils/six/_six.py \
|
||||||
-e lib/ansible/module_utils/six.py \
|
|
||||||
-e test/sanity/code-smell/no-dict-itervalues.sh \
|
-e test/sanity/code-smell/no-dict-itervalues.sh \
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -15,7 +14,6 @@ if [ "${ITERVALUES_USERS}" ]; then
|
||||||
echo 'itervalues has been removed in python3. Alternatives:'
|
echo 'itervalues has been removed in python3. Alternatives:'
|
||||||
echo ' for VALUE in DICT.values():'
|
echo ' for VALUE in DICT.values():'
|
||||||
echo ' from ansible.module_utils.six import itervalues ; for VALUE in itervalues(DICT):'
|
echo ' from ansible.module_utils.six import itervalues ; for VALUE in itervalues(DICT):'
|
||||||
echo ' from ansible.compat.six import itervalues ; for VALUE in itervalues(DICT):'
|
|
||||||
echo "${ITERVALUES_USERS}"
|
echo "${ITERVALUES_USERS}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue