-
Notifications
You must be signed in to change notification settings - Fork 56
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Darker changes lines when the previous lines got changed #388
Comments
This is due to
|
Thanks @wkentaro, this is a great summary and example case for a tricky problem. Since In #221, I attempted a more involved approach by digging into the internals of Black and getting a stream of original/reformatted chunks directly from there, but I very quickly ran into a dead end. There was a fundamental reason why this can't be done in a foolproof way even with Black having access to the AST. Unfortunately I didn't write down the details of it, but it would probably be obvious if we went through it again. It had something to do with indented blocks and the extents of AST nodes. If you're interested to ponder about the problem, we could continue discussion here or maybe in a call. |
Black has evolved quite a bit since I worked on #221, but essentially I tried to reimplement what today is in black._format_str_once() and turn it into a generator of I was hoping to get a more granular list of chunks than what But as said, I failed (or at least was defeated by something that seemed insurmountable). |
Also, having to reimplement parts of Black internals would of course make maintenance of Darker vastly heavier for obvious reasons – at least if we'd like to allow users to benefit from features of new Black versions going forward. |
Oh, I think I now remember a very very difficult case: non-standard indentation. Let's say you have this file: if True:
for x in range(5):
try:
print(10 / x)
except ZeroDivisionError:
print("Can't divide") Currently The dream with more granular handling would of course be that the "wrong" indentation be retained and other reformatting applied. A naïve implementation would simply cause the indentation to not match the surrounding code and be either invalid or not match the original AST. The outermost indentation level could perhaps be reverted in a post-processing step to match surrounding code, but somehow I feel there are going to be nasty edge cases where this would break apart. |
Describe the bug
To Reproduce
darker_tests.zip
Expected behavior
Screenshots
Environment (please complete the following information):
The text was updated successfully, but these errors were encountered: