Skip to content

Conversation

@supertick
Copy link
Contributor

@supertick supertick commented Apr 23, 2024

In general this is the beginning of a much more structured approach of processing in python.
No longer fragile with name dependencies. No global vars at all except runtime.

  • Instead of a variety of python started timers, InMoov2 gets a heart to drive state and other functions. Simple runnable Heart, publishes a heartbeat
  • No python processing untill after "boot" which is when all configuration has processed
  • Scripts executing in apply before InMoov2 has started completely removed
  • Boot function, driven through stages - verifies config has finished before executing scripts
  • Direct references removed from fsm and chatbot
  • getLastActivityTime checks for null
  • isPirActive() added
  • InMoov2 onAudioStart and onAudioEnd added - for callbacks in Python which turn off STT when audioPlayer is running
  • New functions playAudioFile, playMusic, nextPlay, searchPlay because its fun to turn InMoov into a jukebox (and this replaces InMoov2/system/1_AudioFile.py)
  • Removal of onStarted subscription management - it shouldn't be there because it makes it inaccessible to the user
  • FileIO generalized isExecutableAvailable to see if executable is available
  • Runtime checks to see if acpi is availble before checking battery level on Linux
  • Added publishHeartbeat and processMessage - for all future python side processing, potentially compabible with Jython and Py4j
  • InMoov2 setLocale exception when "brain" selected doesn't override i01.chatbot.yml currentBotName
  • Removed startMouth startChatBot which needs to be replaced by the more general startPeer

// getPeerName("python"), "onPythonMessage"));
listeners.add(new Listener("publishProcessMessage", getPeerName("python"), "onPythonMessage"));

listeners.add(new Listener("publishProcessMessage", getPeerName("python"), "onPythonMessage"));
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

should the callback method be onProcessMessage ? to follow our normal convention ? we can refactor this to make it consistent at a later time.

* Checks battery, flashes leds and processes all the configured checks in
* onHeartbeat at a regular interval
*/
public Heartbeat publishHeartbeat() {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this does break with convention a bit.. normally we'd have a publishHeartbeat(Heartbeat beat) ... that simply returns the Heartbeat passed... the code below here, could be handled in the heart thread itself instead.. and just invoking publishHeartbeat with the beat that it created in that cycle... just curious why the departure from that convention?

}
}

public void enable() {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

could this list be more dynamic, perhaps from the default inmoov plan instead of this enumerated list here?


@Deprecated /* use startPeers */
public void startAll() throws Exception {
startAll(null, null);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can we leave this in and have it call startPeers ?

}

@Deprecated /* use startPeers */
public void startAll(String leftPort, String rightPort) throws Exception {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

similar to above, can we just have this call startPeers? leave this method in for convenience sake?

}

public void startHeartbeat() {
addTask(1000, "publishHeartbeat");
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this time should be configurable or pulled out as a constant for the interval here..

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