-
Notifications
You must be signed in to change notification settings - Fork 11
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
Add motor enable 1.0x #140
Conversation
…piod-power-control
Co-authored-by: Dawid Kmak <73443304+KmakD@users.noreply.github.com>
Co-authored-by: Dawid Kmak <73443304+KmakD@users.noreply.github.com>
Co-authored-by: Dawid Kmak <73443304+KmakD@users.noreply.github.com>
…motor-enable-1.0x
motor_state = self._lines['STAGE2_INPUT'].get_value() | ||
# if switch changes from off to on overwrite service value | ||
if not self._last_motor_state and motor_state: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
self._lines['STAGE2_INPUT'].get_value()
bardzo często się pojawia w kodzie proponuje stworzyć lambde is_stage2()
motor_state = self._lines['STAGE2_INPUT'].get_value() | |
# if switch changes from off to on overwrite service value | |
if not self._last_motor_state and motor_state: | |
# if switch changes from off to on overwrite service value | |
if not self._last_motor_state and self.is_stage2(): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It appears 4 times. If we had to add lambda, we would have to do this for both pins and also port it to power_borad_node.py
to keep the same coding style
if not self._last_motor_state and motor_state: | ||
self._motor_enabled = True | ||
|
||
self._last_motor_state = motor_state |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Taught with C++ practice, I think that it would not be a stupid approach to use static variables in such situations. The _last_motor_state
variable is really only needed in this function, so you can encapsulate such things so as not to clutter the whole class.
Example
def my_function(self):
if not hasattr(self.my_function, "counter"):
self.my_function.counter = 0
self.my_function.counter += 1
print(f"Counter: {self.my_function.counter}")
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't see the point. This makes the code less readable. We would have to make an strong assumption the class is a singleton. Even though it would work I do not think assigning variables to a function rather than object is a good idea
Co-authored-by: rafal-gorecki <126687345+rafal-gorecki@users.noreply.github.com>
bump::patch
Port motors enable service behavior to Panther 1.06 and older