Terry J. Reedy <tjre...@udel.edu> added the comment:
As I at least hinted above, I would rather add the missing line starts than delete more. I am quite sure that their absence degrades overall performance in some sense. A much bigger match problem that this one is that ^0 always half fails when the cursor is not on the line with the closer. See #21756, which already has a patch, though not one I was completely happy with last time I looked. I cannot help but think that a proper solution might fix both issues. I once wrote a fence matcher in C, initially for C, based on a deterministic finite state machine but with a push-down stack so it could match indefinite nesting. I am thinking that I should try to rewrite in python and see if it will solve both issues. Find good parse start is not really the right tool, because what we want to do with ^0 is to move both back and forward, find the first unmatched fence in each direction, and flash them, and add a beep if unmatched. BOF and EOF (begin/end of file) are the backup fences. Another possible solution might be to use a depleted _synchre for matching and an augmented one for any other use where that is better. ---------- _______________________________________ Python tracker <rep...@bugs.python.org> <https://bugs.python.org/issue41388> _______________________________________ _______________________________________________ Python-bugs-list mailing list Unsubscribe: https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com