This commit implements the Sideline/Mainline split with a clean plugin architecture: ## Core Changes ### Sideline Framework (New Directory) - Created directory containing the reusable pipeline framework - Moved pipeline core, controllers, adapters, and registry to - Moved display system to - Moved effects system to - Created plugin system with security and compatibility management in - Created preset pack system with ASCII art encoding in - Added default font (Corptic) to - Added terminal ANSI constants to ### Mainline Application (Updated) - Created for Mainline stage component registration - Updated to register Mainline stages at startup - Updated as a compatibility shim re-exporting from sideline ### Terminology Consistency - : Base class for all pipeline components (sources, effects, displays, cameras) - : Base class for distributable plugin packages (was ) - : Base class for visual effects (was ) - Backward compatibility aliases maintained for existing code ## Key Features - Plugin discovery via entry points and explicit registration - Security permissions system for plugins - Compatibility management with semantic version constraints - Preset pack system for distributable configurations - Default font bundled with Sideline (Corptic.otf) ## Testing - Updated tests to register Mainline stages before discovery - All StageRegistry tests passing Note: This is a major refactoring that separates the framework (Sideline) from the application (Mainline), enabling Sideline to be used by other applications.
33 lines
654 B
Python
33 lines
654 B
Python
"""
|
|
Data source types for Sideline.
|
|
|
|
This module defines the data structures used by data sources.
|
|
"""
|
|
|
|
from dataclasses import dataclass
|
|
from typing import Any, Optional
|
|
|
|
|
|
@dataclass
|
|
class SourceItem:
|
|
"""A single item from a data source."""
|
|
|
|
content: str
|
|
source: str
|
|
timestamp: str
|
|
metadata: Optional[dict[str, Any]] = None
|
|
|
|
|
|
@dataclass
|
|
class ImageItem:
|
|
"""An image item from a data source - wraps a PIL Image."""
|
|
|
|
image: Any # PIL Image
|
|
source: str
|
|
timestamp: str
|
|
path: Optional[str] = None # File path or URL if applicable
|
|
metadata: Optional[dict[str, Any]] = None
|
|
|
|
|
|
__all__ = ["SourceItem", "ImageItem"]
|