Linux boca.hozzt.com 4.18.0-553.8.1.lve.el8.x86_64 #1 SMP Thu Jul 4 16:24:39 UTC 2024 x86_64
LiteSpeed
: 159.253.39.62 | : 3.22.240.164
Cant Read [ /etc/named.conf ]
7.4.33
renovkoron
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
opt /
cloudlinux /
venv /
lib /
python3.11 /
site-packages /
pylint /
extensions /
[ HOME SHELL ]
Name
Size
Permission
Action
__pycache__
[ DIR ]
drwxr-xr-x
__init__.py
575
B
-rw-r--r--
_check_docs_utils.py
25.74
KB
-rw-r--r--
bad_builtin.py
2.22
KB
-rw-r--r--
broad_try_clause.py
2.25
KB
-rw-r--r--
check_elif.py
2.09
KB
-rw-r--r--
code_style.py
12.51
KB
-rw-r--r--
comparetozero.py
3.09
KB
-rw-r--r--
comparison_placement.py
2.3
KB
-rw-r--r--
confusing_elif.py
1.99
KB
-rw-r--r--
consider_refactoring_into_whil...
3.23
KB
-rw-r--r--
consider_ternary_expression.py
1.66
KB
-rw-r--r--
dict_init_mutate.py
2.06
KB
-rw-r--r--
docparams.py
25.3
KB
-rw-r--r--
docstyle.py
2.87
KB
-rw-r--r--
dunder.py
2.33
KB
-rw-r--r--
empty_comment.py
1.91
KB
-rw-r--r--
emptystring.py
2.9
KB
-rw-r--r--
eq_without_hash.py
1.42
KB
-rw-r--r--
for_any_all.py
5.69
KB
-rw-r--r--
magic_value.py
4.14
KB
-rw-r--r--
mccabe.py
6.89
KB
-rw-r--r--
no_self_use.py
3.62
KB
-rw-r--r--
overlapping_exceptions.py
3.26
KB
-rw-r--r--
private_import.py
10.97
KB
-rw-r--r--
redefined_loop_name.py
3.14
KB
-rw-r--r--
redefined_variable_type.py
4
KB
-rw-r--r--
set_membership.py
1.75
KB
-rw-r--r--
typing.py
19.91
KB
-rw-r--r--
while_used.py
1.07
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : consider_refactoring_into_while_condition.py
# Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html # For details: https://github.com/PyCQA/pylint/blob/main/LICENSE # Copyright (c) https://github.com/PyCQA/pylint/blob/main/CONTRIBUTORS.txt """Looks for try/except statements with too much code in the try clause.""" from __future__ import annotations from typing import TYPE_CHECKING from astroid import nodes from pylint import checkers from pylint.checkers import utils from pylint.interfaces import HIGH if TYPE_CHECKING: from pylint.lint import PyLinter class ConsiderRefactorIntoWhileConditionChecker(checkers.BaseChecker): """Checks for instances where while loops are implemented with a constant condition which. always evaluates to truthy and the first statement(s) is/are if statements which, when evaluated. to True, breaks out of the loop. The if statement(s) can be refactored into the while loop. """ name = "consider_refactoring_into_while" msgs = { "R3501": ( "Consider using 'while %s' instead of 'while %s:' an 'if', and a 'break'", "consider-refactoring-into-while-condition", "Emitted when `while True:` loop is used and the first statement is a break condition. " "The ``if / break`` construct can be removed if the check is inverted and moved to " "the ``while`` statement.", ), } @utils.only_required_for_messages("consider-refactoring-into-while-condition") def visit_while(self, node: nodes.While) -> None: self._check_breaking_after_while_true(node) def _check_breaking_after_while_true(self, node: nodes.While) -> None: """Check that any loop with an ``if`` clause has a break statement.""" if not isinstance(node.test, nodes.Const) or not node.test.bool_value(): return pri_candidates: list[nodes.If] = [] for n in node.body: if not isinstance(n, nodes.If): break pri_candidates.append(n) candidates = [] tainted = False for c in pri_candidates: if tainted or not isinstance(c.body[0], nodes.Break): break candidates.append(c) orelse = c.orelse while orelse: orelse_node = orelse[0] if not isinstance(orelse_node, nodes.If): tainted = True else: candidates.append(orelse_node) if not isinstance(orelse_node, nodes.If): break orelse = orelse_node.orelse candidates = [n for n in candidates if isinstance(n.body[0], nodes.Break)] msg = " and ".join( [f"({utils.not_condition_as_string(c.test)})" for c in candidates] ) if len(candidates) == 1: msg = utils.not_condition_as_string(candidates[0].test) if not msg: return self.add_message( "consider-refactoring-into-while-condition", node=node, line=node.lineno, args=(msg, node.test.as_string()), confidence=HIGH, ) def register(linter: PyLinter) -> None: linter.register_checker(ConsiderRefactorIntoWhileConditionChecker(linter))
Close