Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
ansible
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenEdx
ansible
Commits
cf82e573
Commit
cf82e573
authored
Feb 18, 2015
by
Toshio Kuratomi
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #10275 from jensdepuydt/optimize-plugin-loader-10165
Optimize plugin loader update
parents
9bb8e60e
730c2ba4
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
11 deletions
+27
-11
lib/ansible/utils/plugins.py
+27
-11
No files found.
lib/ansible/utils/plugins.py
View file @
cf82e573
...
...
@@ -64,6 +64,7 @@ class PluginLoader(object):
self
.
_plugin_path_cache
=
PLUGIN_PATH_CACHE
[
class_name
]
self
.
_extra_dirs
=
[]
self
.
_searched_paths
=
set
()
def
print_paths
(
self
):
''' Returns a string suitable for printing of the search path '''
...
...
@@ -167,22 +168,37 @@ class PluginLoader(object):
else
:
suffixes
=
[
'.py'
,
''
]
# loop over paths and then loop over suffixes to find plugin
for
i
in
self
.
_get_paths
():
for
suffix
in
suffixes
:
full_name
=
'
%
s
%
s'
%
(
name
,
suffix
)
potential_names
=
frozenset
(
'
%
s
%
s'
%
(
name
,
s
)
for
s
in
suffixes
)
for
full_name
in
potential_names
:
if
full_name
in
self
.
_plugin_path_cache
:
return
self
.
_plugin_path_cache
[
full_name
]
found
=
None
for
path
in
[
p
for
p
in
self
.
_get_paths
()
if
p
not
in
self
.
_searched_paths
]:
if
os
.
path
.
isdir
(
path
):
for
potential_file
in
os
.
listdir
(
path
):
for
suffix
in
suffixes
:
if
potential_file
.
endswith
(
suffix
):
full_path
=
os
.
path
.
join
(
path
,
potential_file
)
full_name
=
os
.
path
.
basename
(
full_path
)
break
else
:
# Yes, this is a for-else: http://bit.ly/1ElPkyg
continue
if
full_name
not
in
self
.
_plugin_path_cache
:
self
.
_plugin_path_cache
[
full_name
]
=
full_path
self
.
_searched_paths
.
add
(
path
)
for
full_name
in
potential_names
:
if
full_name
in
self
.
_plugin_path_cache
:
return
self
.
_plugin_path_cache
[
full_name
]
path
=
os
.
path
.
join
(
i
,
full_name
)
if
os
.
path
.
isfile
(
path
):
self
.
_plugin_path_cache
[
full_name
]
=
path
return
path
# if nothing is found, try finding alias/deprecated
if
not
name
.
startswith
(
'_'
):
return
self
.
find_plugin
(
'_'
+
name
,
suffixes
,
transport
)
for
alias_name
in
(
'_
%
s'
%
n
for
n
in
potential_names
):
# We've already cached all the paths at this point
if
alias_name
in
self
.
_plugin_path_cache
:
return
self
.
_plugin_path_cache
[
alias_name
]
return
None
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment