X-Git-Url: http://git.scottworley.com/srec/blobdiff_plain/545a7ac62734b0520e71d89ad4348fe9ba6bc014..8209767e345e49708c246f71fd241c4cc69b70fd:/srec.py?ds=sidebyside diff --git a/srec.py b/srec.py index 01b5a8c..64f2d07 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: @@ -57,13 +74,7 @@ def summarize_size(n: int) -> str: return str(n) -def on_start_recording(_: Gtk.Button, stack: Gtk.Stack) -> None: - global recording # pylint: disable=global-statement - assert recording is None - - filename = make_filename() - size_display = find_size_display(stack) - +def begin_monitoring_file_size(size_display: Gtk.Label, filename: str) -> None: def update_size_display() -> Any: try: size = summarize_size(os.stat(filename).st_size) @@ -73,23 +84,24 @@ 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)) + +def on_start_recording(_: Gtk.Button, stack: Gtk.Stack) -> None: + global recording # pylint: disable=global-statement + assert recording is None + + filename = make_filename() + begin_monitoring_file_size(find_size_display(stack), filename) + + 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")