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
file-contents-sorter
Not working same way everytime
#794
Comments
yeah this set call breaks unique sorting -- it should probably just forbid the combination of unique and ignore case since the result is undefined https://github.com/pre-commit/pre-commit-hooks/blob/v4.3.0/pre_commit_hooks/file_contents_sorter.py#L36 |
@asottile please review if you have time. I'm hoping this PR is simple enough and goes with the spirit of forbidding the combinations of options as you mentioned. Also, I'd appreciate if you could label w/ |
I'm not going to review something which doesn't pass tests |
@asottile Apologies for not seeing the failing tests before asking. I think its ready now. |
Could we respect the original word case if the uncased words are equal? For example, let def key(s):
return (s.lower(), s)
ret = sorted(set(word_list), key=key) Another option is to respect the original order (stable sort). This can use an " def unique(iterable):
return list(OrderedDict.fromkeys(iterable)) # can be replaced with `dict` for Python 3.7+ Both approaches I list above are deterministic. |
no, it should forbid the combination as I said already
…On Mon, Mar 27, 2023, 4:24 AM Xuehai Pan ***@***.***> wrote:
yeah this set call breaks unique sorting -- it should probably just forbid
the combination of unique and ignore case since the result is undefined
v4.3.0/pre_commit_hooks/file_contents_sorter.py#L36
<https://github.com/pre-commit/pre-commit-hooks/blob/v4.3.0/pre_commit_hooks/file_contents_sorter.py?rgh-link-date=2022-07-29T11%3A55%3A28Z#L36>
Could we respect the original word case if the uncased words are equal?
For example, let Pre always proceed pre because it's upper case. This can
be easily implemented with tuple-based sort keys.
def key(s):
return (s.lower(), s)
ret = sorted(set(word_list), key=key)
Another option is to respect the original order (stable sort). This can
use an "OrderedSet" rather than set.
def unique(iterable):
return list(OrderedDict.fromkeys(iterable)) # can be replaced with `dict` for Python 3.7+
—
Reply to this email directly, view it on GitHub
<#794 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAN2BH2U7K4LE7U7DJ5BN5TW6FFD3ANCNFSM55AOQ72Q>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
I get strange issue that file-contents-sorter hook does not work same way everytime. I made little test case which trickers the issue. If i run this 10 times it will sometimes pass and sometimes not. I did not have time to look what problem might be.
Add this to
file_contents_sorter_test.py
And run it with
for run in {1..10}; do pytest tests/file_contents_sorter_test.py; done
This gives me that about 30% pass and 70% fails
The text was updated successfully, but these errors were encountered: