From ed3e2f49841855ff448ac7e8f730b631f45bb9d9 Mon Sep 17 00:00:00 2001 From: Miles Wells Date: Tue, 17 Dec 2024 18:34:40 +0200 Subject: [PATCH] Add extractor tasks to task class; copy video at end of session --- iblrig_custom_tasks/_sp_passiveVideo/task.py | 10 ++++++++++ pyproject.toml | 2 +- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/iblrig_custom_tasks/_sp_passiveVideo/task.py b/iblrig_custom_tasks/_sp_passiveVideo/task.py index 0f733b2..b0c2b3c 100644 --- a/iblrig_custom_tasks/_sp_passiveVideo/task.py +++ b/iblrig_custom_tasks/_sp_passiveVideo/task.py @@ -4,6 +4,7 @@ TODO Add custom task list to Session class """ import time +import shutil from pathlib import Path from collections import defaultdict from functools import partial @@ -157,6 +158,7 @@ class Session(BpodMixin): """Play a single video.""" protocol_name = '_sp_passiveVideo' + extractor_tasks = ['PassiveVideoTimeline'] def __init__(self, **kwargs): super().__init__(**kwargs) @@ -179,6 +181,14 @@ def save(self): if 20 > self._log_level > 0: stats = self.video.stats stats.to_parquet(self.paths.STATS_FILE_PATH) + if self.video._media and self.video._media.get_mrl().endswith(str(self.task_params.VIDEO)): + ext = Path(self.task_params.VIDEO).suffix + video_file_path = self.paths.DATA_FILE_PATH.with_name(f'_sp_video.raw{ext}') + _logger.info('Copying %s -> %s', self.task_params.VIDEO, video_file_path) + shutil.copy(self.task_params.VIDEO, video_file_path) + else: + _logger.warning('Video not copied (video most likely was not played)') + self. self.video._media.get_mrl() self.paths.SESSION_FOLDER.joinpath('transfer_me.flag').touch() def start_hardware(self): diff --git a/pyproject.toml b/pyproject.toml index df0699a..7e96be5 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta" [project] name = "project_extraction" -version = "0.5.2" +version = "0.5.3" description = "Custom extractors for satellite tasks" dynamic = [ "readme" ] keywords = [ "IBL", "neuro-science" ]