Commit f2968d4
committed
Tighten async CM exemption rules
Two refinements in response to review feedback:
- If an `__aenter__`/`__aexit__` method contains any checkpoint-like
construct (`await`, `async with`, or `async for`), it must always
checkpoint. We no longer exempt such methods even when the partner
provides a checkpoint -- conditional checkpoints are still flagged.
- Only charitably assume a missing partner is inherited (with a
checkpoint) when the class actually inherits from something. Classes
with no base classes are treated as flat, and methods that don't
checkpoint are flagged. `metaclass=` and other keyword arguments do
not count as inheriting, since they live in `ClassDef.keywords` rather
than `ClassDef.bases`.
https://claude.ai/code/session_014jAydKywq31Ew4fVYGJdiG1 parent 90d5b7b commit f2968d4
4 files changed
Lines changed: 147 additions & 22 deletions
File tree
- flake8_async/visitors
- tests
- autofix_files
- eval_files
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
467 | 467 | | |
468 | 468 | | |
469 | 469 | | |
470 | | - | |
471 | | - | |
472 | | - | |
473 | | - | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
474 | 474 | | |
| 475 | + | |
| 476 | + | |
| 477 | + | |
| 478 | + | |
475 | 479 | | |
476 | 480 | | |
477 | 481 | | |
| |||
548 | 552 | | |
549 | 553 | | |
550 | 554 | | |
551 | | - | |
| 555 | + | |
552 | 556 | | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
553 | 562 | | |
554 | 563 | | |
555 | 564 | | |
556 | 565 | | |
557 | 566 | | |
558 | 567 | | |
559 | 568 | | |
560 | | - | |
| 569 | + | |
561 | 570 | | |
| 571 | + | |
| 572 | + | |
562 | 573 | | |
563 | 574 | | |
564 | 575 | | |
| |||
574 | 585 | | |
575 | 586 | | |
576 | 587 | | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
577 | 592 | | |
578 | | - | |
579 | 593 | | |
580 | | - | |
581 | | - | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
| 597 | + | |
582 | 598 | | |
583 | 599 | | |
584 | 600 | | |
| |||
609 | 625 | | |
610 | 626 | | |
611 | 627 | | |
| 628 | + | |
612 | 629 | | |
613 | 630 | | |
614 | 631 | | |
| |||
622 | 639 | | |
623 | 640 | | |
624 | 641 | | |
| 642 | + | |
625 | 643 | | |
626 | 644 | | |
627 | 645 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
640 | 640 | | |
641 | 641 | | |
642 | 642 | | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
643 | 647 | | |
644 | 648 | | |
645 | 649 | | |
| |||
676 | 680 | | |
677 | 681 | | |
678 | 682 | | |
679 | | - | |
680 | | - | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
681 | 697 | | |
682 | 698 | | |
683 | 699 | | |
684 | 700 | | |
685 | | - | |
| 701 | + | |
686 | 702 | | |
687 | 703 | | |
688 | 704 | | |
689 | 705 | | |
| 706 | + | |
| 707 | + | |
| 708 | + | |
| 709 | + | |
| 710 | + | |
| 711 | + | |
| 712 | + | |
| 713 | + | |
| 714 | + | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
690 | 720 | | |
691 | 721 | | |
692 | 722 | | |
| |||
697 | 727 | | |
698 | 728 | | |
699 | 729 | | |
| 730 | + | |
| 731 | + | |
| 732 | + | |
| 733 | + | |
| 734 | + | |
| 735 | + | |
| 736 | + | |
| 737 | + | |
| 738 | + | |
| 739 | + | |
| 740 | + | |
700 | 741 | | |
701 | 742 | | |
702 | 743 | | |
703 | 744 | | |
704 | 745 | | |
705 | 746 | | |
706 | 747 | | |
707 | | - | |
| 748 | + | |
708 | 749 | | |
709 | | - | |
| 750 | + | |
710 | 751 | | |
711 | 752 | | |
712 | 753 | | |
713 | 754 | | |
714 | 755 | | |
715 | 756 | | |
716 | | - | |
| 757 | + | |
717 | 758 | | |
718 | 759 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
236 | 236 | | |
237 | 237 | | |
238 | 238 | | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
239 | 268 | | |
240 | 269 | | |
241 | 270 | | |
242 | 271 | | |
243 | 272 | | |
244 | 273 | | |
245 | | - | |
| 274 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
610 | 610 | | |
611 | 611 | | |
612 | 612 | | |
| 613 | + | |
| 614 | + | |
| 615 | + | |
| 616 | + | |
613 | 617 | | |
614 | 618 | | |
615 | 619 | | |
| |||
644 | 648 | | |
645 | 649 | | |
646 | 650 | | |
647 | | - | |
648 | | - | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
649 | 664 | | |
650 | 665 | | |
651 | 666 | | |
652 | 667 | | |
653 | | - | |
| 668 | + | |
654 | 669 | | |
655 | 670 | | |
656 | 671 | | |
657 | 672 | | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
658 | 685 | | |
659 | 686 | | |
660 | 687 | | |
| |||
665 | 692 | | |
666 | 693 | | |
667 | 694 | | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
| 701 | + | |
| 702 | + | |
| 703 | + | |
| 704 | + | |
668 | 705 | | |
669 | 706 | | |
670 | 707 | | |
671 | 708 | | |
672 | 709 | | |
673 | 710 | | |
674 | | - | |
| 711 | + | |
675 | 712 | | |
676 | | - | |
| 713 | + | |
677 | 714 | | |
678 | 715 | | |
679 | 716 | | |
680 | 717 | | |
681 | 718 | | |
682 | 719 | | |
683 | | - | |
| 720 | + | |
684 | 721 | | |
685 | 722 | | |
0 commit comments