{
  "instance_id": "pylint-dev__pylint-7080",
  "repo": "pylint-dev/pylint",
  "created_at": "2022-06-28T17:24:43Z",
  "problem_statement": "`--recursive=y` ignores `ignore-paths`\n### Bug description\r\n\r\nWhen running recursively, it seems `ignore-paths` in my settings in pyproject.toml is completely ignored\r\n\r\n### Configuration\r\n\r\n```ini\r\n[tool.pylint.MASTER]\r\nignore-paths = [\r\n  # Auto generated\r\n  \"^src/gen/.*$\",\r\n]\r\n```\r\n\r\n\r\n### Command used\r\n\r\n```shell\r\npylint --recursive=y src/\r\n```\r\n\r\n\r\n### Pylint output\r\n\r\n```shell\r\n************* Module region_selection\r\nsrc\\region_selection.py:170:0: R0914: Too many local variables (17/15) (too-many-locals)\r\n************* Module about\r\nsrc\\gen\\about.py:2:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\about.py:4:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\about.py:57:0: C0301: Line too long (504/120) (line-too-long)\r\nsrc\\gen\\about.py:12:0: C0103: Class name \"Ui_AboutAutoSplitWidget\" doesn't conform to '_?_?[a-zA-Z]+?$' pattern (invalid-name)\r\nsrc\\gen\\about.py:12:0: R0205: Class 'Ui_AboutAutoSplitWidget' inherits from object, can be safely removed from bases in python3 (useless-object-inheritance)\r\nsrc\\gen\\about.py:13:4: C0103: Method name \"setupUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\about.py:13:22: C0103: Argument name \"AboutAutoSplitWidget\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\about.py:53:4: C0103: Method name \"retranslateUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\about.py:53:28: C0103: Argument name \"AboutAutoSplitWidget\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\about.py:24:8: W0201: Attribute 'ok_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\about.py:27:8: W0201: Attribute 'created_by_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\about.py:30:8: W0201: Attribute 'version_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\about.py:33:8: W0201: Attribute 'donate_text_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\about.py:37:8: W0201: Attribute 'donate_button_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\about.py:43:8: W0201: Attribute 'icon_label' defined outside __init__ (attribute-defined-outside-init)\r\n************* Module design\r\nsrc\\gen\\design.py:2:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\design.py:4:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\design.py:328:0: C0301: Line too long (123/120) (line-too-long)\r\nsrc\\gen\\design.py:363:0: C0301: Line too long (125/120) (line-too-long)\r\nsrc\\gen\\design.py:373:0: C0301: Line too long (121/120) (line-too-long)\r\nsrc\\gen\\design.py:412:0: C0301: Line too long (131/120) (line-too-long)\r\nsrc\\gen\\design.py:12:0: C0103: Class name \"Ui_MainWindow\" doesn't conform to '_?_?[a-zA-Z]+?$' pattern (invalid-name)\r\nsrc\\gen\\design.py:308:8: C0103: Attribute name \"actionSplit_Settings\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:318:8: C0103: Attribute name \"actionCheck_for_Updates_on_Open\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:323:8: C0103: Attribute name \"actionLoop_Last_Split_Image_To_First_Image\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:325:8: C0103: Attribute name \"actionAuto_Start_On_Reset\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:327:8: C0103: Attribute name \"actionGroup_dummy_splits_when_undoing_skipping\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:12:0: R0205: Class 'Ui_MainWindow' inherits from object, can be safely removed from bases in python3 (useless-object-inheritance)\r\nsrc\\gen\\design.py:12:0: R0902: Too many instance attributes (69/15) (too-many-instance-attributes)\r\nsrc\\gen\\design.py:13:4: C0103: Method name \"setupUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:13:22: C0103: Argument name \"MainWindow\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:16:8: C0103: Variable name \"sizePolicy\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:13:4: R0915: Too many statements (339/50) (too-many-statements)\r\nsrc\\gen\\design.py:354:4: C0103: Method name \"retranslateUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:354:28: C0103: Argument name \"MainWindow\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\design.py:354:4: R0915: Too many statements (61/50) (too-many-statements)\r\nsrc\\gen\\design.py:31:8: W0201: Attribute 'central_widget' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:33:8: W0201: Attribute 'x_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:36:8: W0201: Attribute 'select_region_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:40:8: W0201: Attribute 'start_auto_splitter_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:44:8: W0201: Attribute 'reset_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:49:8: W0201: Attribute 'undo_split_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:54:8: W0201: Attribute 'skip_split_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:59:8: W0201: Attribute 'check_fps_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:63:8: W0201: Attribute 'fps_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:66:8: W0201: Attribute 'live_image' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:75:8: W0201: Attribute 'current_split_image' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:81:8: W0201: Attribute 'current_image_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:85:8: W0201: Attribute 'width_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:88:8: W0201: Attribute 'height_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:91:8: W0201: Attribute 'fps_value_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:95:8: W0201: Attribute 'width_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:101:8: W0201: Attribute 'height_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:107:8: W0201: Attribute 'capture_region_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:111:8: W0201: Attribute 'current_image_file_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:115:8: W0201: Attribute 'take_screenshot_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:119:8: W0201: Attribute 'x_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:128:8: W0201: Attribute 'y_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:136:8: W0201: Attribute 'y_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:139:8: W0201: Attribute 'align_region_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:143:8: W0201: Attribute 'select_window_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:147:8: W0201: Attribute 'browse_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:151:8: W0201: Attribute 'split_image_folder_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:154:8: W0201: Attribute 'split_image_folder_input' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:158:8: W0201: Attribute 'capture_region_window_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:162:8: W0201: Attribute 'image_loop_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:165:8: W0201: Attribute 'similarity_viewer_groupbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:169:8: W0201: Attribute 'table_live_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:173:8: W0201: Attribute 'table_highest_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:177:8: W0201: Attribute 'table_threshold_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:181:8: W0201: Attribute 'line_1' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:186:8: W0201: Attribute 'table_current_image_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:189:8: W0201: Attribute 'table_reset_image_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:192:8: W0201: Attribute 'line_2' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:197:8: W0201: Attribute 'line_3' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:202:8: W0201: Attribute 'line_4' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:207:8: W0201: Attribute 'line_5' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:212:8: W0201: Attribute 'table_current_image_live_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:216:8: W0201: Attribute 'table_current_image_highest_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:220:8: W0201: Attribute 'table_current_image_threshold_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:224:8: W0201: Attribute 'table_reset_image_live_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:228:8: W0201: Attribute 'table_reset_image_highest_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:232:8: W0201: Attribute 'table_reset_image_threshold_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:236:8: W0201: Attribute 'reload_start_image_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:240:8: W0201: Attribute 'start_image_status_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:243:8: W0201: Attribute 'start_image_status_value_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:246:8: W0201: Attribute 'image_loop_value_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:249:8: W0201: Attribute 'previous_image_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:254:8: W0201: Attribute 'next_image_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:296:8: W0201: Attribute 'menu_bar' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:299:8: W0201: Attribute 'menu_help' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:301:8: W0201: Attribute 'menu_file' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:304:8: W0201: Attribute 'action_view_help' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:306:8: W0201: Attribute 'action_about' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:308:8: W0201: Attribute 'actionSplit_Settings' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:310:8: W0201: Attribute 'action_save_profile' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:312:8: W0201: Attribute 'action_load_profile' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:314:8: W0201: Attribute 'action_save_profile_as' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:316:8: W0201: Attribute 'action_check_for_updates' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:318:8: W0201: Attribute 'actionCheck_for_Updates_on_Open' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:323:8: W0201: Attribute 'actionLoop_Last_Split_Image_To_First_Image' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:325:8: W0201: Attribute 'actionAuto_Start_On_Reset' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:327:8: W0201: Attribute 'actionGroup_dummy_splits_when_undoing_skipping' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:329:8: W0201: Attribute 'action_settings' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\design.py:331:8: W0201: Attribute 'action_check_for_updates_on_open' defined outside __init__ (attribute-defined-outside-init)\r\n************* Module resources_rc\r\nsrc\\gen\\resources_rc.py:1:0: C0302: Too many lines in module (2311/1000) (too-many-lines)\r\nsrc\\gen\\resources_rc.py:8:0: C0103: Constant name \"qt_resource_data\" doesn't conform to UPPER_CASE naming style (invalid-name)\r\nsrc\\gen\\resources_rc.py:2278:0: C0103: Constant name \"qt_resource_name\" doesn't conform to UPPER_CASE naming style (invalid-name)\r\nsrc\\gen\\resources_rc.py:2294:0: C0103: Constant name \"qt_resource_struct\" doesn't conform to UPPER_CASE naming style (invalid-name)\r\nsrc\\gen\\resources_rc.py:2305:0: C0103: Function name \"qInitResources\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\resources_rc.py:2308:0: C0103: Function name \"qCleanupResources\" doesn't conform to snake_case naming style (invalid-name)\r\n************* Module settings\r\nsrc\\gen\\settings.py:2:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\settings.py:4:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\settings.py:61:0: C0301: Line too long (158/120) (line-too-long)\r\nsrc\\gen\\settings.py:123:0: C0301: Line too long (151/120) (line-too-long)\r\nsrc\\gen\\settings.py:209:0: C0301: Line too long (162/120) (line-too-long)\r\nsrc\\gen\\settings.py:214:0: C0301: Line too long (121/120) (line-too-long)\r\nsrc\\gen\\settings.py:221:0: C0301: Line too long (177/120) (line-too-long)\r\nsrc\\gen\\settings.py:223:0: C0301: Line too long (181/120) (line-too-long)\r\nsrc\\gen\\settings.py:226:0: C0301: Line too long (461/120) (line-too-long)\r\nsrc\\gen\\settings.py:228:0: C0301: Line too long (192/120) (line-too-long)\r\nsrc\\gen\\settings.py:12:0: C0103: Class name \"Ui_DialogSettings\" doesn't conform to '_?_?[a-zA-Z]+?$' pattern (invalid-name)\r\nsrc\\gen\\settings.py:12:0: R0205: Class 'Ui_DialogSettings' inherits from object, can be safely removed from bases in python3 (useless-object-inheritance)\r\nsrc\\gen\\settings.py:12:0: R0902: Too many instance attributes (35/15) (too-many-instance-attributes)\r\nsrc\\gen\\settings.py:13:4: C0103: Method name \"setupUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\settings.py:13:22: C0103: Argument name \"DialogSettings\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\settings.py:16:8: C0103: Variable name \"sizePolicy\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\settings.py:13:4: R0915: Too many statements (190/50) (too-many-statements)\r\nsrc\\gen\\settings.py:205:4: C0103: Method name \"retranslateUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\settings.py:205:28: C0103: Argument name \"DialogSettings\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\settings.py:26:8: W0201: Attribute 'capture_settings_groupbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:29:8: W0201: Attribute 'fps_limit_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:36:8: W0201: Attribute 'fps_limit_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:40:8: W0201: Attribute 'live_capture_region_checkbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:46:8: W0201: Attribute 'capture_method_combobox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:49:8: W0201: Attribute 'capture_method_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:52:8: W0201: Attribute 'capture_device_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:55:8: W0201: Attribute 'capture_device_combobox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:59:8: W0201: Attribute 'image_settings_groupbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:65:8: W0201: Attribute 'default_comparison_method' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:73:8: W0201: Attribute 'default_comparison_method_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:76:8: W0201: Attribute 'default_pause_time_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:80:8: W0201: Attribute 'default_pause_time_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:87:8: W0201: Attribute 'default_similarity_threshold_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:92:8: W0201: Attribute 'default_similarity_threshold_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:98:8: W0201: Attribute 'loop_splits_checkbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:104:8: W0201: Attribute 'custom_image_settings_info_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:111:8: W0201: Attribute 'default_delay_time_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:116:8: W0201: Attribute 'default_delay_time_spinbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:121:8: W0201: Attribute 'hotkeys_groupbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:127:8: W0201: Attribute 'set_pause_hotkey_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:131:8: W0201: Attribute 'split_input' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:137:8: W0201: Attribute 'undo_split_input' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:143:8: W0201: Attribute 'split_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:146:8: W0201: Attribute 'reset_input' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:152:8: W0201: Attribute 'set_undo_split_hotkey_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:156:8: W0201: Attribute 'reset_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:159:8: W0201: Attribute 'set_reset_hotkey_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:163:8: W0201: Attribute 'set_split_hotkey_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:167:8: W0201: Attribute 'pause_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:170:8: W0201: Attribute 'pause_input' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:176:8: W0201: Attribute 'undo_split_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:179:8: W0201: Attribute 'set_skip_split_hotkey_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:183:8: W0201: Attribute 'skip_split_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\settings.py:186:8: W0201: Attribute 'skip_split_input' defined outside __init__ (attribute-defined-outside-init)\r\n************* Module update_checker\r\nsrc\\gen\\update_checker.py:2:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\update_checker.py:4:0: R2044: Line with empty comment (empty-comment)\r\nsrc\\gen\\update_checker.py:12:0: C0103: Class name \"Ui_UpdateChecker\" doesn't conform to '_?_?[a-zA-Z]+?$' pattern (invalid-name)\r\nsrc\\gen\\update_checker.py:12:0: R0205: Class 'Ui_UpdateChecker' inherits from object, can be safely removed from bases in python3 (useless-object-inheritance)\r\nsrc\\gen\\update_checker.py:13:4: C0103: Method name \"setupUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\update_checker.py:13:22: C0103: Argument name \"UpdateChecker\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\update_checker.py:17:8: C0103: Variable name \"sizePolicy\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\update_checker.py:33:8: C0103: Variable name \"sizePolicy\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\update_checker.py:13:4: R0915: Too many statements (56/50) (too-many-statements)\r\nsrc\\gen\\update_checker.py:71:4: C0103: Method name \"retranslateUi\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\update_checker.py:71:28: C0103: Argument name \"UpdateChecker\" doesn't conform to snake_case naming style (invalid-name)\r\nsrc\\gen\\update_checker.py:31:8: W0201: Attribute 'update_status_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:39:8: W0201: Attribute 'current_version_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:42:8: W0201: Attribute 'latest_version_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:45:8: W0201: Attribute 'go_to_download_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:48:8: W0201: Attribute 'left_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:52:8: W0201: Attribute 'right_button' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:55:8: W0201: Attribute 'current_version_number_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:59:8: W0201: Attribute 'latest_version_number_label' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:63:8: W0201: Attribute 'do_not_ask_again_checkbox' defined outside __init__ (attribute-defined-outside-init)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (region_capture -> region_selection) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (error_messages -> user_profile -> region_capture -> region_selection) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplitImage -> split_parser) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoControlledWorker -> error_messages -> AutoSplit) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplit -> user_profile -> region_capture -> region_selection -> error_messages) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplitImage -> error_messages -> user_profile) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplit -> menu_bar -> user_profile -> region_capture -> region_selection -> error_messages) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplit -> region_selection -> error_messages) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplit -> error_messages) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (error_messages -> user_profile -> region_selection) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (error_messages -> user_profile) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplitImage -> split_parser -> error_messages -> user_profile) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplit -> menu_bar -> region_selection -> error_messages) (cyclic-import)\r\nsrc\\gen\\update_checker.py:1:0: R0401: Cyclic import (AutoSplit -> menu_bar -> error_messages) (cyclic-import)\r\n\r\n--------------------------------------------------------------------------\r\nYour code has been rated at -158.32/10 (previous run: -285.20/10, +126.88)\r\n```\r\n\r\n\r\n### Expected behavior\r\n\r\nsrc\\gen\\* should not be checked\r\n\r\n### Pylint version\r\n\r\n```shell\r\npylint 2.14.1\r\nastroid 2.11.5\r\nPython 3.9.6 (tags/v3.9.6:db3ff76, Jun 28 2021, 15:26:21) [MSC v.1929 64 bit (AMD64)]\r\n```\r\n\r\n\r\n### OS / Environment\r\n\r\nWindows 10.0.19044\r\n\r\n\r\n### Additional dependencies\r\n\r\n_No response_\n",
  "patch": "diff --git a/pylint/lint/expand_modules.py b/pylint/lint/expand_modules.py\n--- a/pylint/lint/expand_modules.py\n+++ b/pylint/lint/expand_modules.py\n@@ -52,6 +52,7 @@ def _is_ignored_file(\n     ignore_list_re: list[Pattern[str]],\n     ignore_list_paths_re: list[Pattern[str]],\n ) -> bool:\n+    element = os.path.normpath(element)\n     basename = os.path.basename(element)\n     return (\n         basename in ignore_list\n",
  "similar_bug_items": [
    {
      "pr_number": 6351,
      "pr_title": "Add exception handling for broken config files",
      "pr_body": "Extends the error handling of bad config files, to catch even more errors.\r\n\r\n## Type of Changes\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| \u2713   | :bug: Bug fix          |\r\n\r\n## Description\r\n\r\nCloses #5667\r\n",
      "issue_id": 5667,
      "issue_title": "Add a flag to disable config parsing",
      "issue_body": "### Current problem\r\n\r\nHere's a sample broken `.pylintrc`, placed in the root folder:\r\n\r\n```ini\r\n[pylint]\r\ntest = '%A'\r\n```\r\n\r\nThis is what happens when I try to use pylint now:\r\n```console\r\n$ pylint myfile.py\r\nTraceback (most recent call last):\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/__init__.py\", line 24, in run_pylint\r\n    PylintRun(sys.argv[1:])\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/lint/run.py\", line 324, in __init__\r\n    linter.load_config_file()\r\n  File \"/Users/tusharsadhwani/code/marvin-python/venv3/lib/python3.10/site-packages/pylint/config/option_manager_mixin.py\", line 319, in load_config_file\r\n    for option, value in parser.items(section):\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in items\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 860, in <listcomp>\r\n    return [(option, value_getter(option)) for option in orig_keys]\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 856, in <lambda>\r\n    value_getter = lambda option: self._interpolation.before_get(self,\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 395, in before_get\r\n    self._interpolate_some(parser, option, L, value, section, defaults, 1)\r\n  File \"/usr/local/Cellar/python@3.10/3.10.1/Frameworks/Python.framework/Versions/3.10/lib/python3.10/configparser.py\", line 442, in _interpolate_some\r\n    raise InterpolationSyntaxError(\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint --help   \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n\r\n$ pylint       \r\nTraceback (most recent call last):\r\n[...]\r\nconfigparser.InterpolationSyntaxError: '%' must be followed by '%' or '(', found: \"%A'\"\r\n```\r\n\r\nIs it possible to add a flag that disables config parsing entirely, so that the pylint isn't completely broken when this happens? `--ignore-config-file` for example?\r\n\r\nP.S. this is a feature I want, and I'd be willing to contribute it.",
      "issue_closed_at": "2022-04-15T20:15:52Z",
      "base_commit": "98bb5bf8ebf15fbce960533e5983a71351a1fe3f",
      "changes": [
        {
          "file": "pylint/config/config_file_parser.py",
          "type": "function",
          "name": "parse_config_file",
          "class_name": "_ConfigurationFileParser",
          "code": "def parse_config_file(\n        self, file_path: Path | None\n    ) -> tuple[dict[str, str], list[str]]:\n        \"\"\"Parse a config file and return str-str pairs.\"\"\"\n        if file_path is None:\n            if self.verbose_mode:\n                print(\n                    \"No config file found, using default configuration\", file=sys.stderr\n                )\n            return {}, []\n\n        file_path = Path(os.path.expandvars(file_path)).expanduser()\n        if not file_path.exists():\n            raise OSError(f\"The config file {file_path} doesn't exist!\")\n\n        if self.verbose_mode:\n            print(f\"Using config file {file_path}\", file=sys.stderr)\n\n        if file_path.suffix == \".toml\":\n            return self._parse_toml_file(file_path)\n        return self._parse_ini_file(file_path)"
        }
      ]
    },
    {
      "pr_number": 6481,
      "pr_title": "Fix false positive for ``unused-variable`` when specifying a metaclass via a call",
      "pr_body": "\r\n## Type of Changes\r\n\r\n<!-- Leave the corresponding lines for the applicable type of change: -->\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| \u2713   | :bug: Bug fix          |\r\n\r\n\r\n## Description\r\n\r\nCloses #4020\r\n",
      "issue_id": 4020,
      "issue_title": "unused-variable false positive",
      "issue_body": "<!--\r\n  Hi there! Thank you for discovering and submitting an issue.\r\n\r\n  Before you submit this, make sure that the issue doesn't already exist\r\n  or if it is not closed.\r\n\r\n  Is your issue fixed on the preview release?: pip install pylint astroid --pre -U\r\n\r\n-->\r\n\r\n### Steps to reproduce\r\nThis seems to be the minimal reproducer, \r\n```\r\ndef f():\r\n    def g():\r\n        return type\r\n\r\n    class C(metaclass=g()):\r\n        pass\r\n\r\n    return C\r\n```\r\n\r\n### Current behavior\r\n```\r\ntest.py:5:4: W0612: Unused variable 'g' (unused-variable)\r\n```\r\n\r\n### Expected behavior\r\nNo error, since the function is used.\r\n\r\n### pylint --version output\r\n```\r\npylint 2.6.0\r\nastroid 2.4.2\r\nPython 3.8.7 (default, Dec 24 2020, 17:53:09) \r\n[GCC 10.2.0]\r\n```",
      "issue_closed_at": "2022-05-01T13:53:55Z",
      "base_commit": "5f7fac56b44eb66bba060ec52632bb4ddad21e56",
      "changes": [
        {
          "file": "pylint/checkers/variables.py",
          "type": "function",
          "name": "_check_classdef_metaclasses",
          "class_name": "VariablesChecker",
          "code": "def _check_classdef_metaclasses(self, klass, parent_node):\n        if not klass._metaclass:\n            # Skip if this class doesn't use explicitly a metaclass, but inherits it from ancestors\n            return []\n\n        consumed = []  # [(scope_locals, consumed_key)]\n        metaclass = klass.metaclass()\n        name = None\n        if isinstance(klass._metaclass, nodes.Name):\n            name = klass._metaclass.name\n        elif isinstance(klass._metaclass, nodes.Attribute) and klass._metaclass.expr:\n            attr = klass._metaclass.expr\n            while not isinstance(attr, nodes.Name):\n                attr = attr.expr\n            name = attr.name\n        elif metaclass:\n            name = metaclass.root().name\n\n        found = False\n        name = METACLASS_NAME_TRANSFORMS.get(name, name)\n        if name:\n            # check enclosing scopes starting from most local\n            for scope_locals, _, _, _ in self._to_consume[::-1]:\n                found_nodes = scope_locals.get(name, [])\n                for found_node in found_nodes:\n                    if found_node.lineno <= klass.lineno:\n                        consumed.append((scope_locals, name))\n                        found = True\n                        break\n            # Check parent scope\n            nodes_in_parent_scope = parent_node.locals.get(name, [])\n            for found_node_parent in nodes_in_parent_scope:\n                if found_node_parent.lineno <= klass.lineno:\n                    found = True\n                    break\n        if (\n            not found\n            and not metaclass\n            and not (\n                name in nodes.Module.scope_attrs\n                or utils.is_builtin(name)\n                or name in self.linter.config.additional_builtins\n            )\n        ):\n            self.add_message(\"undefined-variable\", node=klass, args=(name,))\n\n        return consumed"
        }
      ]
    },
    {
      "pr_number": 6944,
      "pr_title": "Mix incorrect parsing of multi-line options in ``ini`` files",
      "pr_body": "- [x] Write a good description on what the PR does.\r\n- [x] Add an entry to the change log describing the change in\r\n  `doc/whatsnew/2/2.15/index.rst` (or ``doc/whatsnew/2/2.14/full.rst``\r\n   if the change needs backporting in 2.14). If necessary you can write\r\n   details or offer examples on how the new change is supposed to work.\r\n- [x] If you used multiple emails or multiple names when contributing, add your mails\r\n      and preferred name in ``script/.contributors_aliases.json``\r\n\r\n## Type of Changes\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| \u2713   | :bug: Bug fix          |\r\n\r\n## Description\r\n\r\nCloses #6888.\r\n\r\nWe could also use an `if` statement to check whether the option is `init-hook` and and then not strip the newlines. But that introduce additional overhead, while this makes pylint faster. The fact that the rest of the test suite passes makes me think that this will be fine. We strip most options of whitespaces in other places anyway.\r\n\r\nIf this regresses after `2.14.2` we can simply add the `if` statement as desired.",
      "issue_id": 6888,
      "issue_title": "init-hook no longer supports multi-line hook",
      "issue_body": "### Bug description\n\nUp to version 2.13.9 multi-line init-hook configurations like the following were supported:\r\n\r\n```\r\ninit-hook=\r\n    try: import pylint_venv\r\n    except ImportError: pass\r\n    else: pylint_venv.inithook()\r\n```\r\n\r\nFrom version 2.14.0 on this no longer works. The error looks like the lines are joined into a single line:\r\n\r\n```\r\n\u276f pylint test.py\r\nTraceback (most recent call last):\r\n  File \"/Users/jgosmann/Library/Python/3.8/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/jgosmann/Library/Python/3.8/lib/python/site-packages/pylint/__init__.py\", line 25, in run_pylint\r\n    PylintRun(argv or sys.argv[1:])\r\n  File \"/Users/jgosmann/Library/Python/3.8/lib/python/site-packages/pylint/lint/run.py\", line 151, in __init__\r\n    args = _config_initialization(\r\n  File \"/Users/jgosmann/Library/Python/3.8/lib/python/site-packages/pylint/config/config_initialization.py\", line 48, in _config_initialization\r\n    exec(utils._unquote(config_data[\"init-hook\"]))  # pylint: disable=exec-used\r\n  File \"<string>\", line 1\r\n    try: import pylint_venvexcept ImportError: passelse: pylint_venv.inithook()\r\n                                  ^\r\nSyntaxError: invalid syntax\r\n```\n\n### Configuration\n\n```ini\ninit-hook=\r\n    try: import pylint_venv\r\n    except ImportError: pass\r\n    else: pylint_venv.inithook()\r\n```\n```\n\n\n### Command used\n\n```shell\npylint test.py\n```\n\n\n### Pylint output\n\n```shell\nTraceback (most recent call last):\r\n  File \"/Users/jgosmann/Library/Python/3.8/bin/pylint\", line 8, in <module>\r\n    sys.exit(run_pylint())\r\n  File \"/Users/jgosmann/Library/Python/3.8/lib/python/site-packages/pylint/__init__.py\", line 25, in run_pylint\r\n    PylintRun(argv or sys.argv[1:])\r\n  File \"/Users/jgosmann/Library/Python/3.8/lib/python/site-packages/pylint/lint/run.py\", line 151, in __init__\r\n    args = _config_initialization(\r\n  File \"/Users/jgosmann/Library/Python/3.8/lib/python/site-packages/pylint/config/config_initialization.py\", line 48, in _config_initialization\r\n    exec(utils._unquote(config_data[\"init-hook\"]))  # pylint: disable=exec-used\r\n  File \"<string>\", line 1\r\n    try: import pylint_venvexcept ImportError: passelse: pylint_venv.inithook()\r\n                                  ^\r\nSyntaxError: invalid syntax\n```\n\n\n### Expected behavior\n\nThe init-hook runs without a syntax error.\n\n### Pylint version\n\n```shell\npylint 2.14.0 (and 2.14.1)\r\nastroid 2.11.5\r\nPython 3.8.13 (default, May 10 2022, 11:26:18)\r\n[Clang 13.0.0 (clang-1300.0.29.3)]\n```\n\n\n### OS / Environment\n\n_No response_\n\n### Additional dependencies\n\npylint-venv==2.2.0",
      "issue_closed_at": "2022-06-13T16:24:32Z",
      "base_commit": "c21261eb4c0e2a0ec4c239b6f9af3f3a746b01cc",
      "changes": [
        {
          "file": "pylint/config/config_file_parser.py",
          "type": "function",
          "name": "_parse_ini_file",
          "class_name": "_ConfigurationFileParser",
          "code": "def _parse_ini_file(self, file_path: Path) -> tuple[dict[str, str], list[str]]:\n        \"\"\"Parse and handle errors of a ini configuration file.\"\"\"\n        parser = configparser.ConfigParser(inline_comment_prefixes=(\"#\", \";\"))\n\n        # Use this encoding in order to strip the BOM marker, if any.\n        with open(file_path, encoding=\"utf_8_sig\") as fp:\n            parser.read_file(fp)\n\n        config_content: dict[str, str] = {}\n        options: list[str] = []\n        for section in parser.sections():\n            if self._ini_file_with_sections(str(file_path)) and not section.startswith(\n                \"pylint\"\n            ):\n                if section.lower() == \"master\":\n                    # TODO: 3.0: Remove deprecated handling of master, only allow 'pylint.' sections\n                    warnings.warn(\n                        \"The use of 'MASTER' or 'master' as configuration section for pylint \"\n                        \"has been deprecated, as it's bad practice to not start sections titles with the \"\n                        \"tool name. Please use 'pylint.main' instead.\",\n                        UserWarning,\n                    )\n                else:\n                    continue\n            for opt, value in parser[section].items():\n                value = value.replace(\"\\n\", \"\")\n                config_content[opt] = value\n                options += [f\"--{opt}\", value]\n        return config_content, options"
        },
        {
          "file": "pylint/config/config_initialization.py",
          "type": "function",
          "name": "_config_initialization",
          "class_name": null,
          "code": "def _config_initialization(\n    linter: PyLinter,\n    args_list: list[str],\n    reporter: reporters.BaseReporter | reporters.MultiReporter | None = None,\n    config_file: None | str | Path = None,\n    verbose_mode: bool = False,\n) -> list[str]:\n    \"\"\"Parse all available options, read config files and command line arguments and\n    set options accordingly.\n    \"\"\"\n    config_file = Path(config_file) if config_file else None\n\n    # Set the current module to the configuration file\n    # to allow raising messages on the configuration file.\n    linter.set_current_module(str(config_file) if config_file else \"\")\n\n    # Read the configuration file\n    config_file_parser = _ConfigurationFileParser(verbose_mode, linter)\n    try:\n        config_data, config_args = config_file_parser.parse_config_file(\n            file_path=config_file\n        )\n    except OSError as ex:\n        print(ex, file=sys.stderr)\n        sys.exit(32)\n\n    # Run init hook, if present, before loading plugins\n    if \"init-hook\" in config_data:\n        exec(utils._unquote(config_data[\"init-hook\"]))  # pylint: disable=exec-used\n\n    # Load plugins if specified in the config file\n    if \"load-plugins\" in config_data:\n        linter.load_plugin_modules(utils._splitstrip(config_data[\"load-plugins\"]))\n\n    unrecognized_options_message = None\n    # First we parse any options from a configuration file\n    try:\n        linter._parse_configuration_file(config_args)\n    except _UnrecognizedOptionError as exc:\n        unrecognized_options_message = \", \".join(exc.options)\n\n    # Then, if a custom reporter is provided as argument, it may be overridden\n    # by file parameters, so we re-set it here. We do this before command line\n    # parsing, so it's still overridable by command line options\n    if reporter:\n        linter.set_reporter(reporter)\n\n    # Set the current module to the command line\n    # to allow raising messages on it\n    linter.set_current_module(\"Command line\")\n\n    # Now we parse any options from the command line, so they can override\n    # the configuration file\n    parsed_args_list = linter._parse_command_line_configuration(args_list)\n\n    # Check if there are any options that we do not recognize\n    unrecognized_options: list[str] = []\n    for opt in parsed_args_list:\n        if opt.startswith(\"--\"):\n            unrecognized_options.append(opt[2:])\n        elif opt.startswith(\"-\"):\n            unrecognized_options.append(opt[1:])\n    if unrecognized_options:\n        msg = \", \".join(unrecognized_options)\n        linter._arg_parser.error(f\"Unrecognized option found: {msg}\")\n\n    # Now that config file and command line options have been loaded\n    # with all disables, it is safe to emit messages\n    if unrecognized_options_message is not None:\n        linter.set_current_module(str(config_file) if config_file else \"\")\n        linter.add_message(\n            \"unrecognized-option\", args=unrecognized_options_message, line=0\n        )\n\n    linter._emit_stashed_messages()\n\n    # Set the current module to configuration as we don't know where\n    # the --load-plugins key is coming from\n    linter.set_current_module(\"Command line or configuration file\")\n\n    # We have loaded configuration from config file and command line. Now, we can\n    # load plugin specific configuration.\n    linter.load_plugin_configuration()\n\n    # Now that plugins are loaded, get list of all fail_on messages, and enable them\n    linter.enable_fail_on_messages()\n\n    linter._parse_error_mode()\n\n    # Link the base Namespace object on the current directory\n    linter._directory_namespaces[Path(\".\").resolve()] = (linter.config, {})\n\n    # parsed_args_list should now only be a list of files/directories to lint.\n    # All other options have been removed from the list.\n    return parsed_args_list"
        }
      ]
    },
    {
      "pr_number": 4202,
      "pr_title": "Fix tox -e pylint and pre commit",
      "pr_body": "## Description\r\n\r\nThe ``pre-commit run pylint`` command was not exactly the same than ``tox -e pylint``\r\n\r\n## Type of Changes\r\n<!-- Leave the corresponding lines for the applicable type of change: -->\r\n|   | Type |\r\n| ------------- | ------------- |\r\n| \u2713  | :bug: Bug fix  |\r\n\r\n## Related Issue\r\n\r\nCloses #4201 \r\n",
      "issue_id": 4201,
      "issue_title": "tox -e pylint failing",
      "issue_body": "Commit 6721cd1c causes a failure in the `pylint` testenv under `tox`.\r\n\r\n### Steps to reproduce\r\n\r\n1. Check out commit 6721cd1c\r\n2. `tox -e pylint` (or `tox`)\r\n\r\n### Current behavior\r\n```\r\n************* Module pylint.checkers.deprecated\r\npylint/checkers/deprecated.py:55:4: W9012: Missing return type documentation (missing-return-type-doc)\r\npylint/checkers/deprecated.py:64:4: W9012: Missing return type documentation (missing-return-type-doc)\r\n\r\n--------------------------------------------------------------------\r\nYour code has been rated at 10.00/10 (previous run: 10.00/10, -0.00)\r\n\r\nERROR: InvocationError for command /home/kolbus/projects/pylint/.tox/pylint/bin/pylint -rn --rcfile=/home/kolbus/projects/pylint/pylintrc --load-plugins=pylint.extensions.docparams, pylint.extensions.mccabe pylint tests/message tests/checkers tests/extensions tests/utils tests/acceptance tests/conftest.py tests/test_config.py tests/test_func.py tests/test_functional.py tests/test_import_graph.py tests/test_pragma_parser.py tests/test_pylint_runners.py tests/test_regr.py tests/test_self.py tests/unittest_config.py tests/lint tests/unittest_pyreverse_diadefs.py tests/unittest_pyreverse_inspector.py tests/unittest_pyreverse_writer.py tests/unittest_reporters_json.py tests/unittest_reporting.py (exited with code 4)\r\n__________________________________________________________________________________________________________ summary __________________________________________________________________________________________________________\r\nERROR:   pylint: commands failed\r\n```\r\n\r\n### Expected behavior\r\n\r\nNo errors\r\n",
      "issue_closed_at": "2021-03-07T09:39:07Z",
      "base_commit": "6721cd1cf2da0294124b75d382a042e23ec27d47",
      "changes": [
        {
          "file": "examples/deprecation_checker.py",
          "type": "class",
          "name": "DeprecationChecker",
          "code": "class DeprecationChecker(DeprecatedMixin, BaseChecker):\n    \"\"\"Class implementing deprecation checker.\"\"\"\n\n    # DeprecationMixin class is Mixin class implementing logic for searching deprecated methods and functions.\n    # The list of deprecated methods/functions is defined by implementing class via deprecated_methods callback.\n    # DeprecatedMixin class is overriding attributes of BaseChecker hence must be specified *before* BaseChecker\n    # in list of base classes.\n\n    __implements__ = (IAstroidChecker,)\n    # The name defines a custom section of the config for this checker.\n    name = \"deprecated\"\n\n    def deprecated_methods(self):\n        \"\"\"Callback method called by DeprecatedMixin for every method/function found in the code.\n\n        Returns:\n            collections.abc.Container of deprecated function/method names.\n        \"\"\"\n        return {\"mymodule.deprecated_function\", \"mymodule.MyClass.deprecated_method\"}\n\n    def deprecated_arguments(self, method: str):\n        \"\"\"Callback returning the deprecated arguments of method/function.\n\n        Returns:\n            collections.abc.Iterable in form:\n                ((POSITION1, PARAM1), (POSITION2: PARAM2) ...)\n            where\n                * POSITIONX - position of deprecated argument PARAMX in function definition.\n                  If argument is keyword-only, POSITIONX should be None.\n                * PARAMX - name of the deprecated argument.\n        \"\"\"\n        if method == \"mymodule.myfunction\":\n            # myfunction() has two deprecated arguments:\n            # * deprecated_arg1 defined at 2nd position and\n            # * deprecated_arg2 defined at 5th position.\n            return ((2, \"deprecated_arg1\"), (5, \"deprecated_arg2\"))\n        if method == \"mymodule.MyClass.mymethod\":\n            # mymethod() has two deprecated arguments:\n            # * deprecated1 defined at 2nd position and\n            # * deprecated2 defined at 4th position.\n            return ((2, \"deprecated1\"), (4, \"deprecated2\"))\n        return ()"
        },
        {
          "file": "examples/deprecation_checker.py",
          "type": "function",
          "name": "deprecated_methods",
          "class_name": "DeprecationChecker",
          "code": "def deprecated_methods(self):\n        \"\"\"Callback method called by DeprecatedMixin for every method/function found in the code.\n\n        Returns:\n            collections.abc.Container of deprecated function/method names.\n        \"\"\"\n        return {\"mymodule.deprecated_function\", \"mymodule.MyClass.deprecated_method\"}"
        },
        {
          "file": "pylint/checkers/deprecated.py",
          "type": "line",
          "name": "line 2",
          "code": "# For details: https://github.com/PyCQA/pylint/blob/master/COPYING\n\n\"\"\"Checker mixin for deprecated functionality.\"\"\"\n\nfrom itertools import chain\nfrom typing import Any\n"
        },
        {
          "file": "pylint/checkers/deprecated.py",
          "type": "function",
          "name": "deprecated_methods",
          "class_name": "DeprecatedMixin",
          "code": "def deprecated_methods(self):\n        \"\"\"Callback returning the deprecated methods/functions.\n\n        Returns:\n            collections.abc.Container of deprecated function/method names.\n        \"\"\"\n        # pylint: disable=no-self-use\n        return ()"
        }
      ]
    },
    {
      "pr_number": 6556,
      "pr_title": "Fix disabling of ``bad-option-value``",
      "pr_body": "- [x] Add a ChangeLog entry describing what your PR does.\r\n- [x] If it's a new feature, or an important bug fix, add a What's New entry in\r\n      `doc/whatsnew/<current release.rst>`.\r\n- [x] Write a good description on what the PR does.\r\n- [x] If you used multiple emails or multiple names when contributing, add your mails\r\n   and preferred name in ``script/.contributors_aliases.json``\r\n\r\n## Type of Changes\r\n\r\n|     | Type                   |\r\n| --- | ---------------------- |\r\n| \u2713   | :bug: Bug fix          |\r\n\r\n## Description\r\n\r\nCloses #3312.\r\n",
      "issue_id": 3312,
      "issue_title": "Can't disable bad-option-value",
      "issue_body": "### Steps to reproduce\r\n1. Write code on a computer with a somewhat new pylint (2.4.3 in my example). Get a warning like `useless-object-inheritance` that I want to ignore, as I'm writing code compatible with python2 and python3.\r\n2. Disable said warning with `# pylint: disable=useless-object-inheritance`.\r\n3. Get a \"Bad option value\" when other people run their pylint version (example: 2.3.1; and by people, sometimes I mean docker instances ran from Jenkins that I would rather not rebuild or that depend on other people and I can't modify)\r\n4. Try to disable said error with a global `# pylint: disable=bad-option-value`\r\n\r\n### Current behavior\r\n`# pylint: disable=bad-option-value` is ignored\r\n`# pylint: disable=E0012` is ignored\r\n\r\n### Expected behavior\r\nTo be able to write code that works on several versions of pylint and not having to make sure every computer in the company and every docker container has the same pylint version.\r\n\r\n",
      "issue_closed_at": "2022-05-09T21:25:39Z",
      "base_commit": "fa183c7d15b5f3c7dd8dee86fc74caae42c3926c",
      "changes": [
        {
          "file": "pylint/lint/pylinter.py",
          "type": "function",
          "name": "_check_astroid_module",
          "class_name": "PyLinter",
          "code": "def _check_astroid_module(\n        self,\n        node: nodes.Module,\n        walker: ASTWalker,\n        rawcheckers: list[checkers.BaseRawFileChecker],\n        tokencheckers: list[checkers.BaseTokenChecker],\n    ) -> bool | None:\n        \"\"\"Check given AST node with given walker and checkers.\n\n        :param astroid.nodes.Module node: AST node of the module to check\n        :param pylint.utils.ast_walker.ASTWalker walker: AST walker\n        :param list rawcheckers: List of token checkers to use\n        :param list tokencheckers: List of raw checkers to use\n\n        :returns: True if the module was checked, False if ignored,\n            None if the module contents could not be parsed\n        \"\"\"\n        try:\n            tokens = utils.tokenize_module(node)\n        except tokenize.TokenError as ex:\n            self.add_message(\"syntax-error\", line=ex.args[1][0], args=ex.args[0])\n            return None\n\n        if not node.pure_python:\n            self.add_message(\"raw-checker-failed\", args=node.name)\n        else:\n            # assert astroid.file.endswith('.py')\n            # Parse module/block level option pragma's\n            self.process_tokens(tokens)\n            if self._ignore_file:\n                return False\n            # walk ast to collect line numbers\n            self.file_state.collect_block_lines(self.msgs_store, node)\n            # run raw and tokens checkers\n            for raw_checker in rawcheckers:\n                raw_checker.process_module(node)\n            for token_checker in tokencheckers:\n                token_checker.process_tokens(tokens)\n        # generate events to astroid checkers\n        walker.walk(node)\n        return True"
        },
        {
          "file": "pylint/utils/file_state.py",
          "type": "function",
          "name": "collect_block_lines",
          "class_name": "FileState",
          "code": "def collect_block_lines(\n        self, msgs_store: MessageDefinitionStore, module_node: nodes.Module\n    ) -> None:\n        \"\"\"Walk the AST to collect block level options line numbers.\"\"\"\n        for msg, lines in self._module_msgs_state.items():\n            self._raw_module_msgs_state[msg] = lines.copy()\n        orig_state = self._module_msgs_state.copy()\n        self._module_msgs_state = {}\n        self._suppression_mapping = {}\n        self._effective_max_line_number = module_node.tolineno\n        self._collect_block_lines(msgs_store, module_node, orig_state)"
        },
        {
          "file": "pylint/utils/file_state.py",
          "type": "function",
          "name": "_collect_block_lines",
          "class_name": "FileState",
          "code": "def _collect_block_lines(\n        self,\n        msgs_store: MessageDefinitionStore,\n        node: nodes.NodeNG,\n        msg_state: MessageStateDict,\n    ) -> None:\n        \"\"\"Recursively walk (depth first) AST to collect block level options\n        line numbers.\n        \"\"\"\n        for child in node.get_children():\n            self._collect_block_lines(msgs_store, child, msg_state)\n        # first child line number used to distinguish between disable\n        # which are the first child of scoped node with those defined later.\n        # For instance in the code below:\n        #\n        # 1.   def meth8(self):\n        # 2.        \"\"\"test late disabling\"\"\"\n        # 3.        pylint: disable=not-callable, useless-suppression\n        # 4.        print(self.blip)\n        # 5.        pylint: disable=no-member, useless-suppression\n        # 6.        print(self.bla)\n        #\n        # E1102 should be disabled from line 1 to 6 while E1101 from line 5 to 6\n        #\n        # this is necessary to disable locally messages applying to class /\n        # function using their fromlineno\n        if (\n            isinstance(node, (nodes.Module, nodes.ClassDef, nodes.FunctionDef))\n            and node.body\n        ):\n            firstchildlineno = node.body[0].fromlineno\n        else:\n            firstchildlineno = node.tolineno\n        for msgid, lines in msg_state.items():\n            for msg in msgs_store.get_message_definitions(msgid):\n                self._set_message_state_in_block(msg, lines, node, firstchildlineno)"
        },
        {
          "file": "pylint/utils/file_state.py",
          "type": "function",
          "name": "_set_message_state_in_block",
          "class_name": "FileState",
          "code": "def _set_message_state_in_block(\n        self,\n        msg: MessageDefinition,\n        lines: dict[int, bool],\n        node: nodes.NodeNG,\n        firstchildlineno: int,\n    ) -> None:\n        \"\"\"Set the state of a message in a block of lines.\"\"\"\n        first = node.fromlineno\n        last = node.tolineno\n        for lineno, state in list(lines.items()):\n            original_lineno = lineno\n            if first > lineno or last < lineno:\n                continue\n            # Set state for all lines for this block, if the\n            # warning is applied to nodes.\n            if msg.scope == WarningScope.NODE:\n                if lineno > firstchildlineno:\n                    state = True\n                first_, last_ = node.block_range(lineno)\n            else:\n                first_ = lineno\n                last_ = last\n            for line in range(first_, last_ + 1):\n                # do not override existing entries\n                if line in self._module_msgs_state.get(msg.msgid, ()):\n                    continue\n                if line in lines:  # state change in the same block\n                    state = lines[line]\n                    original_lineno = line\n                if not state:\n                    self._suppression_mapping[(msg.msgid, line)] = original_lineno\n                try:\n                    self._module_msgs_state[msg.msgid][line] = state\n                except KeyError:\n                    self._module_msgs_state[msg.msgid] = {line: state}\n            del lines[lineno]"
        },
        {
          "file": "pylint/utils/file_state.py",
          "type": "function",
          "name": "_set_message_state_in_block",
          "class_name": "FileState",
          "code": "def _set_message_state_in_block(\n        self,\n        msg: MessageDefinition,\n        lines: dict[int, bool],\n        node: nodes.NodeNG,\n        firstchildlineno: int,\n    ) -> None:\n        \"\"\"Set the state of a message in a block of lines.\"\"\"\n        first = node.fromlineno\n        last = node.tolineno\n        for lineno, state in list(lines.items()):\n            original_lineno = lineno\n            if first > lineno or last < lineno:\n                continue\n            # Set state for all lines for this block, if the\n            # warning is applied to nodes.\n            if msg.scope == WarningScope.NODE:\n                if lineno > firstchildlineno:\n                    state = True\n                first_, last_ = node.block_range(lineno)\n            else:\n                first_ = lineno\n                last_ = last\n            for line in range(first_, last_ + 1):\n                # do not override existing entries\n                if line in self._module_msgs_state.get(msg.msgid, ()):\n                    continue\n                if line in lines:  # state change in the same block\n                    state = lines[line]\n                    original_lineno = line\n                if not state:\n                    self._suppression_mapping[(msg.msgid, line)] = original_lineno\n                try:\n                    self._module_msgs_state[msg.msgid][line] = state\n                except KeyError:\n                    self._module_msgs_state[msg.msgid] = {line: state}\n            del lines[lineno]"
        }
      ]
    }
  ]
}