X-Git-Url: http://git.scottworley.com/srec/blobdiff_plain/bde510f000f49fd4dd0265e201d1e765a2c44db6..e5b09945620ccdc8759cf6fe8f885854b6837596:/srec.py diff --git a/srec.py b/srec.py index bacc1df..944cc5c 100644 --- a/srec.py +++ b/srec.py @@ -4,10 +4,13 @@ # under the terms of the GNU General Public License as published by the # Free Software Foundation, version 3. +from __future__ import annotations + from dataclasses import dataclass from datetime import datetime import os import subprocess +import sys from typing import Any, Callable import gi @@ -19,12 +22,26 @@ from gi.repository import GLib # nopep8 pylint: disable=wrong-import-position @dataclass -class Recording: - filename: str +class Stream: process: subprocess.Popen[bytes] + @staticmethod + def start(command: list[str]) -> Stream: + # pylint: disable=consider-using-with + return Stream(process=subprocess.Popen(command, stdin=subprocess.PIPE)) + + def stop(self) -> None: + stdin = self.process.stdin + assert stdin is not None + try: + stdin.write(b'q') + stdin.flush() + except BrokenPipeError: + print("Stream already stopped?", file=sys.stderr) + self.process.wait() + -recording: Recording | None = None +recording: Stream | None = None def make_filename() -> str: @@ -73,23 +90,16 @@ def on_start_recording(_: Gtk.Button, stack: Gtk.Stack) -> None: return GLib.SOURCE_REMOVE if recording is None else GLib.SOURCE_CONTINUE GLib.timeout_add_seconds(1, update_size_display) - command = (['ffmpeg', '-framerate', '25'] + video_source(stack) + - ['-f', 'pulse', '-ac', '2', '-i', 'default', filename]) - # pylint: disable=consider-using-with - recording = Recording( - filename=filename, - process=subprocess.Popen(command, stdin=subprocess.PIPE)) + recording = Stream.start( + ['ffmpeg', '-framerate', '25'] + video_source(stack) + + ['-f', 'pulse', '-ac', '2', '-i', 'default', filename]) stack.set_visible_child_name("recording") def on_stop_recording(_: Gtk.Button, stack: Gtk.Stack) -> None: global recording # pylint: disable=global-statement assert recording is not None - stdin = recording.process.stdin - assert stdin is not None - stdin.write(b'q') - stdin.flush() - recording.process.wait() + recording.stop() recording = None stack.set_visible_child_name("not_recording") @@ -106,7 +116,7 @@ def make_button(label: str, action: Callable[[ def make_share_control() -> Gtk.CheckButton: - can_share = os.path.exists('/sys/module/v4l2looback') + can_share = os.path.exists('/sys/module/v4l2loopback') control = Gtk.CheckButton( label='Share Webcam', sensitive=can_share, active=can_share) control.set_margin_start(20)