Skip to content
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

Fix ColorAlignment.custom_colors.keys() / slots type mismatch #303

Merged
merged 1 commit into from
Oct 23, 2024

Conversation

luna-1024
Copy link
Contributor

This is something I am running into while working on an bigger PR (and need to resolve it) and I think it would be good to separately get a quick fix in.

In the ColorAlignment dataclass, the type annotation of custom_color keys (int) does not match the type of the of slots (set of str (which are numeric characters)), which is used to construct the ColorAlignment instance. (The value of that field ends up not the correct type).

Additionally, since this value is saved in the hyfetch.json, serialization for json only supports strings as keys means that the keys go into the json as strs. And it's involved to avoid saving the keys as str. There are outstanding user configs already with serialized string keys. De-serializing those configs also result in str keys in the custom_color field.

I think the resolution is one of the following options:

  1. Change the type annotation to custom_colors: dict[str, int] = ()
  2. Fix the construction of slots to be a set[int], and one of:
    a. Enhance the deserialization to generally recognise int str keys.
    b. Add a fixup step to ColorAlignment.from_dict

I chose solution 2b here as it is simple and it respects the apparent authorial intent that the custom_colors should be an dict[int, int], which in general makes sense to me. This solution would not in any way preclude smoothly moving to str keys in the future if more slots support is desired with for example letter based slots ${cA} ${cB}.

@luna-1024 luna-1024 force-pushed the custom-colors-type-fix branch from 2105709 to abfa093 Compare May 30, 2024 08:32
@luna-1024 luna-1024 force-pushed the custom-colors-type-fix branch from abfa093 to 45347e0 Compare July 12, 2024 17:51
@hykilpikonna hykilpikonna merged commit b0b8c51 into hykilpikonna:master Oct 23, 2024
1 check passed
hykilpikonna added a commit that referenced this pull request Oct 23, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants