Initial implementation: full Ableton Live 11 OSC remote script

Covers all major Live API objects with get/set/listen/method handlers:
song, track, return_track, clip, clip_slot, device (incl. rack chains
and drum pads), scene, view, application, browser, groove.

Zero external runtime dependencies — OSC encoded/decoded in osc_server.py.
Wildcard * support for track/scene indices. Listener callbacks fire to
matching /get/ addresses for bidirectional state sync.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-06-01 12:27:47 +02:00
commit aad042650e
17 changed files with 3159 additions and 0 deletions
+51
View File
@@ -0,0 +1,51 @@
"""Handles /live/application/* OSC addresses."""
import logging
from typing import Optional
from .handler import AbletonOSCHandler
logger = logging.getLogger(__name__)
class ApplicationHandler(AbletonOSCHandler):
def init_api(self) -> None:
self.clear_listeners()
self._add("/live/application/get/version", self._get_version)
self._add("/live/application/get/average_process_usage",
self._get_average_process_usage)
self._add("/live/application/get/peak_process_usage",
self._get_peak_process_usage)
def _app(self):
try:
return self.manager.application()
except Exception:
return None
def _get_version(self, params: tuple) -> Optional[tuple]:
app = self._app()
if app:
try:
major, minor = app.get_major_version(), app.get_minor_version()
build = app.get_bugfix_version()
return (major, minor, build)
except Exception as e:
logger.warning("get version: %s", e)
return None
def _get_average_process_usage(self, params: tuple) -> Optional[tuple]:
app = self._app()
if app:
try:
return (float(app.average_process_usage),)
except Exception as e:
logger.warning("get avg process usage: %s", e)
return None
def _get_peak_process_usage(self, params: tuple) -> Optional[tuple]:
app = self._app()
if app:
try:
return (float(app.peak_process_usage),)
except Exception as e:
logger.warning("get peak process usage: %s", e)
return None