jenkins-bot merged this change.

View Change

Approvals: Xqt: Looks good to me, approved jenkins-bot: Verified
[cleanup] pwb.py: Flat is better than nested

Remove nested filename condition and make the code more flat
in that way:

if foo:
doing_a_long_statement_list()
return True
else:
return False

is changed to

if not foo:
return False
doing_a_long_statement_list()
return True

The code inside "if" kept unchanged

Change-Id: Iad4f58adf8dfc2b8111b3c86c5af2a2e92e8b350
---
M pwb.py
1 file changed, 72 insertions(+), 72 deletions(-)

diff --git a/pwb.py b/pwb.py
index 164d44c..a07690a 100755
--- a/pwb.py
+++ b/pwb.py
@@ -171,80 +171,80 @@
def main():
"""Command line entry point."""
global filename
- if filename:
- file_package = None
- argvu = pwb.argvu[1:]
- if not os.path.exists(filename):
- script_paths = ['scripts',
- 'scripts.maintenance',
- 'scripts.userscripts']
- from pywikibot import config
- if config.user_script_paths:
- if isinstance(config.user_script_paths, (tuple, list)):
- script_paths = config.user_script_paths + script_paths
- else:
- warn("'user_script_paths' must be a list or tuple,\n"
- 'found: {0}. Ignoring this setting.'
- ''.format(type(config.user_script_paths)))
- for file_package in script_paths:
- paths = file_package.split('.') + [filename]
- testpath = os.path.join(_pwb_dir, *paths)
- if os.path.exists(testpath):
- filename = testpath
- break
- else:
- print('ERROR: {} not found! Misspelling?'.format(filename),
- file=sys.stderr)
-
- scripts = {}
- for file_package in script_paths:
- path = file_package.split('.')
- for script_name in os.listdir(os.path.join(*path)):
- if (script_name.endswith('.py')
- and not script_name.startswith('__')):
- # remove .py for better matching
- scripts[script_name[:-3]] = os.path.join(
- *(path + [script_name]))
-
- similar_scripts = get_close_matches(filename[:-3], scripts,
- n=10, cutoff=0.7)
- if similar_scripts:
- print('\nThe most similar script{}:'
- .format(' is' if len(similar_scripts) == 1
- else 's are'))
- print('\t' + '.py\n\t'.join(similar_scripts) + '.py')
- return True
-
- # When both pwb.py and the filename to run are within the current
- # working directory:
- # a) set __package__ as if called using python -m scripts.blah.foo
- # b) set __file__ to be relative, so it can be relative in backtraces,
- # and __file__ *appears* to be an unstable path to load data from.
- # This is a rough (and quick!) emulation of 'package name' detection.
- # a much more detailed implementation is in coverage's find_module.
- # https://bitbucket.org/ned/coveragepy/src/default/coverage/execfile.py
- cwd = abspath(os.getcwd())
- if absolute_path == cwd:
- absolute_filename = abspath(filename)[:len(cwd)]
- if absolute_filename == cwd:
- relative_filename = os.path.relpath(filename)
- # remove the filename, and use '.' instead of path separator.
- file_package = os.path.dirname(
- relative_filename).replace(os.sep, '.')
- filename = os.path.join(os.curdir, relative_filename)
-
- if file_package and file_package not in sys.modules:
- try:
- import_module(file_package)
- except ImportError as e:
- warn('Parent module %s not found: %s'
- % (file_package, e), ImportWarning)
-
- run_python_file(filename, [filename] + args, argvu, file_package)
- return True
- else:
+ if not filename:
return False

+ file_package = None
+ argvu = pwb.argvu[1:]
+ if not os.path.exists(filename):
+ script_paths = ['scripts',
+ 'scripts.maintenance',
+ 'scripts.userscripts']
+ from pywikibot import config
+ if config.user_script_paths:
+ if isinstance(config.user_script_paths, (tuple, list)):
+ script_paths = config.user_script_paths + script_paths
+ else:
+ warn("'user_script_paths' must be a list or tuple,\n"
+ 'found: {0}. Ignoring this setting.'
+ ''.format(type(config.user_script_paths)))
+ for file_package in script_paths:
+ paths = file_package.split('.') + [filename]
+ testpath = os.path.join(_pwb_dir, *paths)
+ if os.path.exists(testpath):
+ filename = testpath
+ break
+ else:
+ print('ERROR: {} not found! Misspelling?'.format(filename),
+ file=sys.stderr)
+
+ scripts = {}
+ for file_package in script_paths:
+ path = file_package.split('.')
+ for script_name in os.listdir(os.path.join(*path)):
+ if (script_name.endswith('.py')
+ and not script_name.startswith('__')):
+ # remove .py for better matching
+ scripts[script_name[:-3]] = os.path.join(
+ *(path + [script_name]))
+
+ similar_scripts = get_close_matches(filename[:-3], scripts,
+ n=10, cutoff=0.7)
+ if similar_scripts:
+ print('\nThe most similar script{}:'
+ .format(' is' if len(similar_scripts) == 1
+ else 's are'))
+ print('\t' + '.py\n\t'.join(similar_scripts) + '.py')
+ return True
+
+ # When both pwb.py and the filename to run are within the current
+ # working directory:
+ # a) set __package__ as if called using python -m scripts.blah.foo
+ # b) set __file__ to be relative, so it can be relative in backtraces,
+ # and __file__ *appears* to be an unstable path to load data from.
+ # This is a rough (and quick!) emulation of 'package name' detection.
+ # a much more detailed implementation is in coverage's find_module.
+ # https://bitbucket.org/ned/coveragepy/src/default/coverage/execfile.py
+ cwd = abspath(os.getcwd())
+ if absolute_path == cwd:
+ absolute_filename = abspath(filename)[:len(cwd)]
+ if absolute_filename == cwd:
+ relative_filename = os.path.relpath(filename)
+ # remove the filename, and use '.' instead of path separator.
+ file_package = os.path.dirname(
+ relative_filename).replace(os.sep, '.')
+ filename = os.path.join(os.curdir, relative_filename)
+
+ if file_package and file_package not in sys.modules:
+ try:
+ import_module(file_package)
+ except ImportError as e:
+ warn('Parent module %s not found: %s'
+ % (file_package, e), ImportWarning)
+
+ run_python_file(filename, [filename] + args, argvu, file_package)
+ return True
+

if __name__ == '__main__':
if not main():

To view, visit change 508857. To unsubscribe, or for help writing mail filters, visit settings.

Gerrit-Project: pywikibot/core
Gerrit-Branch: master
Gerrit-MessageType: merged
Gerrit-Change-Id: Iad4f58adf8dfc2b8111b3c86c5af2a2e92e8b350
Gerrit-Change-Number: 508857
Gerrit-PatchSet: 3
Gerrit-Owner: Xqt <info@gno.de>
Gerrit-Reviewer: Dvorapa <dvorapa@seznam.cz>
Gerrit-Reviewer: John Vandenberg <jayvdb@gmail.com>
Gerrit-Reviewer: Xqt <info@gno.de>
Gerrit-Reviewer: jenkins-bot (75)