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

Best Practices #90

Open
10 tasks
jolpica opened this issue Sep 27, 2022 · 0 comments
Open
10 tasks

Best Practices #90

jolpica opened this issue Sep 27, 2022 · 0 comments

Comments

@jolpica
Copy link

jolpica commented Sep 27, 2022

If we aim to follow best practices in the code base, it should make the project more maintainable, customisable and easier to use.

Here are a few suggestions
High priority:

  • Replace all occurrences of type(<obj>).__name__ == "<Class>" with isinstance(<Class>, <obj>).
    This will allow custom subclasses to be made and used with the project in the future
  • When checking for None obj is [not] None should be used instead of type (as above) or ==
  • Default arguments in should never be mutable (e.g. a list or dictionary) as they are not reset between function calls and this can lead to bugs. Instead, set default to None and replace None with the required value in the function.
  • When checking if a value is True or "Truthy" use if value and never if value == True.
    if value is True should be avoided unless checking for exactly True (will be false if compared to numpy's value of True)

Medium Priority:

  • Use f-strings instead using .format on strings, this makes reading and writing much clearer
    e.g. replace "pet-{}".format(name) with f"pet-{name}"
  • Define all class attributes (self.attribute) inside the __init__ function, even if setting to None.
  • Never use import * as this makes it hard to find the source of a function.
  • Use type annotations in public methods (e.g. oteam: Team) making it easier to understand and gaining better autocomplete
  • Use clearer names, not always clear what oteam / fteam / apet means, friendly_team, enemy_team is much clearer (and autocomplete will help with the extra characters)
  • Follow public/private naming conventions. Anything that starts with an _ (e.g. self._variable) should be treated as private and not be used outside the Class definition. At the moment we regularly use _health and _attack of the pet class. A solution could be to create setter functions (.set_attack) or rename them (.base_attack)
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

No branches or pull requests

1 participant