+ timestamp = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
+ return os.path.join(directory, f'srec {timestamp}.mkv')
+
+
+def video_source(stack: Gtk.Stack) -> list[str]:
+ if stack.get_child_by_name('not_recording').get_first_child().get_active():
+ return ['-f', 'x11grab', '-i', ':0.0+0,0']
+ if is_sharing_enabled(stack):
+ return ['-f', 'v4l2', '-i', '/dev/video9']
+ return ['-f', 'v4l2', '-i', '/dev/video0']
+
+
+def is_sharing_enabled(stack: Gtk.Stack) -> bool:
+ enabled = stack.get_child_by_name('not_recording').get_first_child(
+ ).get_next_sibling().get_next_sibling().get_active()
+ assert isinstance(enabled, bool)
+ return enabled
+
+
+def find_size_display(stack: Gtk.Stack) -> Gtk.Label:
+ return stack.get_child_by_name(
+ 'recording').get_first_child().get_next_sibling()
+
+
+def summarize_size(n: int) -> str:
+ if n > 100_000_000:
+ m = int(n / (1024 * 1024))
+ return f'{m}M'
+ if n > 100_000:
+ k = int(n / 1024)
+ return f'{k}K'
+ return str(n)
+
+
+def begin_monitoring_file_size(size_display: Gtk.Label, filename: str) -> None:
+ def update_size_display() -> Any:
+ done = recording is None
+ if done:
+ size_display.set_label('')
+ else:
+ try:
+ size = summarize_size(os.stat(filename).st_size)
+ except FileNotFoundError:
+ size = '--'
+ size_display.set_label(f'<big>{size}</big>')
+ return GLib.SOURCE_REMOVE if done else GLib.SOURCE_CONTINUE
+ GLib.timeout_add_seconds(1, update_size_display)