From be7dca40f872346f0d9300f4e800aaa35f55a73b Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 25 May 2026 20:03:19 +0000 Subject: [PATCH 1/2] [pre-commit.ci] pre-commit autoupdate MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit updates: - [github.com/sirosen/check-jsonschema: 0.23.2 → 0.37.2](https://github.com/sirosen/check-jsonschema/compare/0.23.2...0.37.2) - [github.com/AleksaC/hadolint-py: v2.12.0.2 → v2.14.0](https://github.com/AleksaC/hadolint-py/compare/v2.12.0.2...v2.14.0) - [github.com/scop/pre-commit-shfmt: v3.7.0-1 → v3.13.1-1](https://github.com/scop/pre-commit-shfmt/compare/v3.7.0-1...v3.13.1-1) - [github.com/shellcheck-py/shellcheck-py: v0.9.0.5 → v0.11.0.1](https://github.com/shellcheck-py/shellcheck-py/compare/v0.9.0.5...v0.11.0.1) - https://github.com/psf/black → https://github.com/psf/black-pre-commit-mirror - [github.com/psf/black-pre-commit-mirror: 23.3.0 → 26.5.1](https://github.com/psf/black-pre-commit-mirror/compare/23.3.0...26.5.1) - [github.com/pre-commit/mirrors-clang-format: v16.0.6 → v22.1.5](https://github.com/pre-commit/mirrors-clang-format/compare/v16.0.6...v22.1.5) - [github.com/executablebooks/mdformat: 0.7.16 → 1.0.0](https://github.com/executablebooks/mdformat/compare/0.7.16...1.0.0) - [github.com/jackdewinter/pymarkdown: v0.9.11 → v0.9.37](https://github.com/jackdewinter/pymarkdown/compare/v0.9.11...v0.9.37) - [github.com/pre-commit/pre-commit-hooks: v4.4.0 → v6.0.0](https://github.com/pre-commit/pre-commit-hooks/compare/v4.4.0...v6.0.0) --- .pre-commit-config.yaml | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 17002ca..2ce1d07 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -8,7 +8,7 @@ exclude: (?i)^(.*third[^/]*party/.*|.*\.ts|.*\.trt)$ repos: - repo: https://github.com/sirosen/check-jsonschema # check-jsonschema is a github actions and workflows verifier. - rev: 0.23.2 + rev: 0.37.2 hooks: - id: check-github-actions - id: check-github-workflows @@ -20,7 +20,7 @@ repos: exclude: (?i)(.*docker-compose.*)$ # by-pass docker-compose since the %YAML 1.2 will break it. - repo: https://github.com/AleksaC/hadolint-py # hadolint is a Dockerfile linter. - rev: v2.12.0.2 + rev: v2.14.0 hooks: - id: hadolint args: @@ -28,26 +28,26 @@ repos: - error - repo: https://github.com/scop/pre-commit-shfmt # pre-commit-shfmt formats shell scripts. - rev: v3.7.0-1 + rev: v3.13.1-1 hooks: - id: shfmt - repo: https://github.com/shellcheck-py/shellcheck-py # shellcheck-py is a shellcheck wrapper. - rev: v0.9.0.5 + rev: v0.11.0.1 hooks: - id: shellcheck args: - -e - SC1071,SC1091 - - repo: https://github.com/psf/black # The uncompromising Python code formatter. - rev: 23.3.0 + - repo: https://github.com/psf/black-pre-commit-mirror # The uncompromising Python code formatter. + rev: 26.5.1 hooks: - id: black - id: black-jupyter - repo: https://github.com/pre-commit/mirrors-clang-format # mirrors-clang-format is a clang-format wrapper, it can format json - rev: v16.0.6 + rev: v22.1.5 hooks: - id: clang-format # files: (?i)\.(h|c|hpp|cpp|hxx|cxx|cc)$ @@ -63,12 +63,12 @@ repos: - id: cmake-format - repo: https://github.com/executablebooks/mdformat # mdformat is a markdown formatter. - rev: 0.7.16 + rev: 1.0.0 hooks: - id: mdformat - repo: https://github.com/jackdewinter/pymarkdown # pymarkdown is a markdown linter. - rev: v0.9.11 + rev: v0.9.37 hooks: - id: pymarkdown args: @@ -77,7 +77,7 @@ repos: - scan - repo: https://github.com/pre-commit/pre-commit-hooks # pre-commit-hooks is a collection of additional pre-commit hooks. - rev: v4.4.0 + rev: v6.0.0 hooks: - id: requirements-txt-fixer # fixes requirements.txt and requirements-dev.txt. - id: check-added-large-files # prevents giant files from being committed. From 8fcbc2c71bd93e68ad5840686063e37fa6741631 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 25 May 2026 20:03:31 +0000 Subject: [PATCH 2/2] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- conversion.ipynb | 3932 +++++++++++++++++++-------------------- docker/config/.p10k.zsh | 3269 ++++++++++++++++---------------- 2 files changed, 3601 insertions(+), 3600 deletions(-) diff --git a/conversion.ipynb b/conversion.ipynb index eb08b6d..31cb4ba 100644 --- a/conversion.ipynb +++ b/conversion.ipynb @@ -1,1968 +1,1968 @@ { - "cells": [ - { - "cell_type": "code", - "execution_count": 1, - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "/usr/bin/zsh\n", - "/opt/ros/noetic/etc/catkin/profile.d/50-rosmon.zsh:66: command not found: compdef\n" - ] - } - ], - "source": [ - "# =============================================================================\n", - "# Created on Wed Jun 07 2023 16:09:02\n", - "# Author: Mukai (Tom Notch) Yu\n", - "# Email: mukaiy@andrew.cmu.edu\n", - "# Affiliation: Carnegie Mellon University, Robotics Institute, the AirLab\n", - "#\n", - "# Copyright Ⓒ 2023 Mukai (Tom Notch) Yu\n", - "# =============================================================================\n", - "\n", - "\n", - "! echo $SHELL\n", - "! source /opt/ros/noetic/setup.zsh" - ] - }, - { - "cell_type": "code", - "execution_count": 2, - "metadata": {}, - "outputs": [], - "source": [ - "import gi\n", - "\n", - "gi.require_version(\"Gst\", \"1.0\")\n", - "from gi.repository import Gst\n", - "from sensor_msgs.msg import Image\n", - "import cv2\n", - "import numpy as np\n", - "import os\n", - "import re\n", - "import rosbag\n", - "import rospy\n", - "import time\n", - "import threading\n", - "import yaml" - ] - }, - { - "cell_type": "code", - "execution_count": 3, - "metadata": {}, - "outputs": [], - "source": [ - "file_type_to_extension = {\n", - " \"mp4\": \".mp4\",\n", - " \"rosbag\": \".bag\",\n", - " \"directory\": \"\",\n", - " \"YAML\": \".yaml\",\n", - "}" - ] - }, - { - "cell_type": "code", - "execution_count": 4, - "metadata": {}, - "outputs": [], - "source": [ - "def load_config(cfg_path: str) -> dict:\n", - " with open(cfg_path) as f:\n", - " cfg: dict = yaml.safe_load(f)\n", - " return cfg\n", - "\n", - "\n", - "def print_dict(d: dict, indent: int = 0):\n", - " for key, value in d.items():\n", - " if isinstance(value, dict):\n", - " print(\" \" * indent + str(key) + \": \")\n", - " print_dict(value, indent + 1)\n", - " else:\n", - " print(\" \" * indent + str(key) + \": \" + str(value))" - ] - }, - { - "cell_type": "code", - "execution_count": 5, - "metadata": {}, - "outputs": [], - "source": [ - "class ImgDirOutput:\n", - " def __init__(self, name: str, output: dict):\n", - " self.name = name\n", - " self.path = output[\"path\"]\n", - " self.directory = output[\"directory\"]\n", - "\n", - " assert (\n", - " output[\"type\"] == \"directory\"\n", - " ), f'{self.name}\\'s output type {output[\"type\"]} is inappropriate for ImgDirOutput Class.'\n", - "\n", - " def callback(self, image, time_stamp: int) -> None:\n", - " output_image = cv2.cvtColor(image, cv2.COLOR_RGB2BGR)\n", - " cv2.imwrite(\n", - " os.path.join(self.directory, str(time_stamp) + \".png\"), output_image\n", - " )\n", - "\n", - " def close(self) -> None:\n", - " pass" - ] - }, - { - "cell_type": "code", - "execution_count": 6, - "metadata": {}, - "outputs": [], - "source": [ - "class RosbagOutput:\n", - " def __init__(self, name: str, output: dict):\n", - " self.name = name\n", - " self.path = output[\"path\"]\n", - " self.directory = output[\"directory\"]\n", - " self.topic = output[\"topic\"]\n", - " self.frame_id = output.get(\"frame_id\", None)\n", - "\n", - " assert (\n", - " output[\"type\"] == \"rosbag\"\n", - " ), f'{self.name}\\'s output type {output[\"type\"]} is inappropriate for RosbagOutput Class.'\n", - "\n", - " self.init_rosbag()\n", - "\n", - " def init_rosbag(self) -> None:\n", - " self.bag = rosbag.Bag(self.path, \"w\")\n", - "\n", - " self.image_msg = Image()\n", - " if self.frame_id is not None:\n", - " self.image_msg.header.frame_id = self.frame_id\n", - " self.image_msg.encoding = \"rgb8\"\n", - " self.image_msg.header.seq = -1\n", - "\n", - " def callback(self, image, time_stamp: int) -> None:\n", - " self.image_msg.header.stamp = rospy.Time(\n", - " secs=int(time_stamp // 1e9), nsecs=int(time_stamp % 1e9)\n", - " )\n", - " self.image_msg.header.seq += 1\n", - " self.image_msg.height = image.shape[0]\n", - " self.image_msg.width = image.shape[1]\n", - " self.image_msg.step = self.image_msg.width * 3\n", - " self.image_msg.data = image.tobytes()\n", - "\n", - " self.bag.write(self.topic, self.image_msg, t=self.image_msg.header.stamp)\n", - "\n", - " def close(self) -> None:\n", - " self.bag.close()" - ] - }, - { - "cell_type": "code", - "execution_count": 7, - "metadata": {}, - "outputs": [], - "source": [ - "class MP4Input:\n", - " def __init__(self, name: str, input: dict, outputs: dict):\n", - " \"\"\"initialize the MP4Input class\n", - "\n", - " Args:\n", - " name (str): name of this pipeline in the yaml config, used in named sink of gstreamer pipeline\n", - " input (dict): input config\n", - " output (list): list of output class instances, this input class only uses their callback functions\n", - " \"\"\"\n", - " Gst.init(None)\n", - " self.name = name\n", - " self.path = input[\"path\"]\n", - " if not input[\"type\"] == \"mp4\": # verify type is correct\n", - " raise ValueError(\n", - " f'Input type {input[\"type\"]} is inappropriate for MP4Input Class.'\n", - " )\n", - "\n", - " self.width = input.get(\"width\", None)\n", - " self.height = input.get(\"height\", None)\n", - " self.start = input.get(\"start\", None)\n", - " self.end = input.get(\"end\", None)\n", - " self.output_callbacks = [output.callback for output in outputs.values()]\n", - " self.close_handlers = [output.close for output in outputs.values()]\n", - "\n", - " self.setup()\n", - "\n", - " def setup(self):\n", - " self.parse_start_time()\n", - "\n", - " self.bytes_per_pixel = 3 # since it's in RGB format\n", - " self.current_relative_time = 0\n", - "\n", - " # setup gstreamer pipeline\n", - " self.gstreamer_pipeline_str = (\n", - " \"filesrc location=\"\n", - " + self.path\n", - " + \" ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB\"\n", - " )\n", - " if self.width:\n", - " self.gstreamer_pipeline_str += \",width=\" + str(self.width)\n", - " if self.height:\n", - " self.gstreamer_pipeline_str += \",height=\" + str(self.height)\n", - " self.gstreamer_pipeline_str += (\n", - " \" ! progressreport update-freq=1 name=\"\n", - " + self.name\n", - " + \"_progress ! fakesink name=\"\n", - " + self.name\n", - " )\n", - " print(\n", - " self.name\n", - " + \" MP4Input's gstreamer pipeline string: \"\n", - " + self.gstreamer_pipeline_str\n", - " )\n", - " self.gstreamer_pipeline = Gst.parse_launch(self.gstreamer_pipeline_str)\n", - " self.gstreamer_pipeline.get_by_name(self.name).get_static_pad(\"sink\").add_probe(\n", - " Gst.PadProbeType.BUFFER, self.callback\n", - " )\n", - "\n", - " def parse_start_time(self):\n", - " \"\"\"parse the absolute start time in nanoseconds from the file name\"\"\"\n", - " match = re.search(r\"(\\d{10}_\\d{9})(?=\\.\\w+$)\", self.path)\n", - " assert (\n", - " match is not None\n", - " ), f\"{self.path} does not contain the proper timestamp sub-string.\"\n", - " time_str = match[1].split(\"_\")\n", - " self.absolute_start_time = int(time_str[0]) * int(1e9) + int(time_str[1])\n", - "\n", - " def callback(self, pad, info):\n", - " image, self.current_relative_time = self.get_frame(pad, info)\n", - "\n", - " # check if the current frame is within the start and end time\n", - " if (self.start and self.current_relative_time * 1e-9 < self.start) or (\n", - " self.end and self.current_relative_time * 1e-9 > self.end\n", - " ):\n", - " return Gst.PadProbeReturn.OK\n", - "\n", - " current_absolute_time = self.absolute_start_time + self.current_relative_time\n", - "\n", - " # calling callbacks for each output pipeline\n", - " for callback in self.output_callbacks:\n", - " callback(image, current_absolute_time)\n", - "\n", - " return Gst.PadProbeReturn.OK\n", - "\n", - " def get_frame(self, pad, info):\n", - " buffer = info.get_buffer()\n", - " caps = pad.get_current_caps()\n", - "\n", - " caps_structure = caps.get_structure(0)\n", - " height, width = caps_structure.get_value(\"height\"), caps_structure.get_value(\n", - " \"width\"\n", - " )\n", - "\n", - " is_mapped, map_info = buffer.map(Gst.MapFlags.READ)\n", - " if is_mapped:\n", - " try:\n", - " image = np.ndarray(\n", - " (height, width, self.bytes_per_pixel),\n", - " dtype=\"uint8\",\n", - " buffer=map_info.data,\n", - " ).copy() # extend array lifetime beyond subsequent unmap\n", - " finally:\n", - " buffer.unmap(map_info)\n", - "\n", - " return (\n", - " image,\n", - " buffer.pts,\n", - " ) # using pts instead of dts since it's set in the mp4 file recorded using https://bitbucket.org/castacks/image_sharing/src/c5ab07622155793ff756020d1a8117a7d5036325/src/tools/to_gstreamer.cpp#lines-156\n", - "\n", - " def loop(self):\n", - " self.gstreamer_pipeline.set_state(Gst.State.PLAYING)\n", - "\n", - " try:\n", - " while True:\n", - " msg = self.gstreamer_pipeline.get_bus().timed_pop_filtered(\n", - " Gst.SECOND * 5, Gst.MessageType.EOS | Gst.MessageType.ERROR\n", - " ) #! 5 seconds timeout\n", - "\n", - " if msg:\n", - " if msg.type == Gst.MessageType.EOS:\n", - " break\n", - " elif msg.type == Gst.MessageType.ERROR:\n", - " raise Exception(\n", - " \"GStreamer stream Error occurred in pipeline: \" + self.name\n", - " )\n", - "\n", - " # # Query position and duration to display progress\n", - " # success, position = self.gstreamer_pipeline.query_position(Gst.Format.TIME)\n", - " # success, duration = self.gstreamer_pipeline.query_duration(Gst.Format.TIME)\n", - "\n", - " # if success and duration != Gst.CLOCK_TIME_NONE and duration != 0:\n", - " # progress = (position / duration) * 100\n", - " # print(f\"{self.name}\\'s progress: {progress:.2f}%\")\n", - "\n", - " #! delay for 5 seconds since the progress query is blocking\n", - " time.sleep(5)\n", - " finally:\n", - " self.gstreamer_pipeline.set_state(Gst.State.NULL)\n", - "\n", - " # call close handlers for each output pipeline\n", - " for close_handler in self.close_handlers:\n", - " close_handler()\n", - " print(f\"Pipeline {self.name} finished.\")" - ] - }, - { - "cell_type": "code", - "execution_count": 8, - "metadata": {}, - "outputs": [], - "source": [ - "class Pipeline(threading.Thread):\n", - " def __init__(self, name: str, pipeline: dict):\n", - " super().__init__()\n", - " self.name = name\n", - " self.outputs = self.init_outputs(pipeline[\"output\"])\n", - " self.input = self.init_input(pipeline[\"input\"])\n", - "\n", - " def init_outputs(self, outputs_dict: dict):\n", - " outputs = {}\n", - " for (\n", - " name,\n", - " output,\n", - " ) in outputs_dict.items(): # name is arbitrary and doesn't matter\n", - " output_type = output[\"type\"]\n", - " assert (\n", - " output_type in file_type_to_extension.keys()\n", - " ), f\"pipeline {self.name} output's file type {output_type} is not supported\"\n", - " if output_type == \"directory\":\n", - " outputs[name] = ImgDirOutput(name, output)\n", - " elif output_type == \"rosbag\":\n", - " outputs[name] = RosbagOutput(name, output)\n", - " return outputs\n", - "\n", - " def init_input(self, input_dict: dict):\n", - " assert (\n", - " input_dict[\"type\"] in file_type_to_extension.keys()\n", - " ), f'pipeline {self.name} input\\'s file type {input_dict[\"type\"]} is not supported'\n", - " if input_dict[\"type\"] == \"mp4\":\n", - " return MP4Input(self.name, input_dict, self.outputs)\n", - "\n", - " def run(self):\n", - " print(f\"{self.name} pipeline started.\")\n", - " self.input.loop()" - ] - }, - { - "cell_type": "code", - "execution_count": 9, - "metadata": {}, - "outputs": [], - "source": [ - "def verify_file(path: str, type: str) -> bool:\n", - " # verify the file/directory exists\n", - " assert os.path.exists(path), f\"file {path} does not exist\"\n", - "\n", - " # verify the file type is supported\n", - " assert type in file_type_to_extension.keys(), f\"file type {type} is not supported\"\n", - "\n", - " # verify the file type matches the extension or the path is a directory\n", - " if type == \"directory\":\n", - " assert os.path.isdir(path), f\"{path} is not a directory\"\n", - " else:\n", - " assert (\n", - " os.path.splitext(path)[-1] == file_type_to_extension[type]\n", - " ), f\"file {path} is not a {type} file\"\n", - "\n", - " return True\n", - "\n", - "\n", - "def trace_config(cfg: dict):\n", - " pipelines = []\n", - " # verify that the config file contains \"pipelines\"\n", - " assert (\n", - " \"pipelines\" in cfg and cfg[\"pipelines\"]\n", - " ), \"pipeline is not specified in config file\"\n", - "\n", - " print(\"Loaded config:\")\n", - " print(\"pipelines: \", end=\"\")\n", - " print(cfg[\"pipelines\"], end=\"\\n\\n\")\n", - "\n", - " for pipeline_name in cfg[\"pipelines\"]:\n", - " # verify that the pipeline is specified in the config file\n", - " assert (\n", - " pipeline_name in cfg\n", - " ), f\"pipeline {pipeline_name} is not specified in config file\"\n", - "\n", - " pipeline = cfg[pipeline_name]\n", - "\n", - " # make directories for output and verify type\n", - " for index, output in pipeline[\"output\"].items():\n", - " # verify the file type is supported\n", - " assert (\n", - " output[\"type\"] in file_type_to_extension.keys()\n", - " ), f'pipeline {pipeline_name}\\'s output {index}\\'s file type {output[\"type\"]} is not supported'\n", - "\n", - " # make parent directories if they don't exist\n", - " output[\"directory\"] = (\n", - " os.path.dirname(output[\"path\"])\n", - " if (output[\"type\"] == \"directory\")\n", - " else os.path.dirname(output[\"path\"])\n", - " )\n", - " os.makedirs(output[\"directory\"], exist_ok=True)\n", - "\n", - " # verify input\n", - " assert verify_file(\n", - " path=pipeline[\"input\"][\"path\"], type=pipeline[\"input\"][\"type\"]\n", - " ), f'pipeline {pipeline_name}\\'s input file {pipeline[\"input\"][\"path\"]} is not valid'\n", - "\n", - " print(pipeline_name + \":\")\n", - " print_dict(pipeline, indent=1)\n", - "\n", - " pipelines.append(Pipeline(pipeline_name, pipeline))\n", - "\n", - " return pipelines" - ] - }, - { - "cell_type": "code", - "execution_count": 10, - "metadata": {}, - "outputs": [], - "source": [ - "cfg_path = \"./config/wildfire/subcanopy/mp4_to_imgdir_rosbag.yaml\"\n", - "\n", - "cfg = load_config(cfg_path)" - ] - }, - { - "cell_type": "code", - "execution_count": 11, - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "Loaded config:\n", - "pipelines: ['camera_0', 'camera_1', 'camera_2', 'camera_3']\n", - "\n", - "camera_0:\n", - " input: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_0_1677761985_629121776.mp4\n", - " type: mp4\n", - " width: 612\n", - " height: 514\n", - " output: \n", - " 2: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_0.bag\n", - " type: rosbag\n", - " topic: /camera_0\n", - " frame_id: camera_0/optical_frame\n", - " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", - "camera_0 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_0_1677761985_629121776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_0_progress ! fakesink name=camera_0\n", - "camera_1:\n", - " input: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_1_1677761985_962133776.mp4\n", - " type: mp4\n", - " width: 612\n", - " height: 514\n", - " output: \n", - " 2: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_1.bag\n", - " type: rosbag\n", - " topic: /camera_1\n", - " frame_id: camera_1/optical_frame\n", - " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", - "camera_1 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_1_1677761985_962133776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_1_progress ! fakesink name=camera_1\n", - "camera_2:\n", - " input: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_2_1677761986_311796776.mp4\n", - " type: mp4\n", - " width: 612\n", - " height: 514\n", - " output: \n", - " 2: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_2.bag\n", - " type: rosbag\n", - " topic: /camera_2\n", - " frame_id: camera_2/optical_frame\n", - " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", - "camera_2 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_2_1677761986_311796776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_2_progress ! fakesink name=camera_2\n", - "camera_3:\n", - " input: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_3_1677761986_644808776.mp4\n", - " type: mp4\n", - " width: 612\n", - " height: 514\n", - " output: \n", - " 2: \n", - " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_3.bag\n", - " type: rosbag\n", - " topic: /camera_3\n", - " frame_id: camera_3/optical_frame\n", - " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", - "camera_3 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_3_1677761986_644808776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_3_progress ! fakesink name=camera_3\n", - "camera_0 pipeline started.\n", - "camera_1 pipeline started.\n", - "camera_2 pipeline started.\n", - "camera_3 pipeline started.\n", - "camera_3_progress (00:00:01): 0 / 918 seconds ( 0.0 %)\n", - "camera_0_progress (00:00:01): 1 / 919 seconds ( 0.1 %)\n", - "camera_2_progress (00:00:01): 0 / 918 seconds ( 0.0 %)\n", - "camera_1_progress (00:00:01): 0 / 918 seconds ( 0.0 %)\n", - "camera_1_progress (00:00:02): 5 / 918 seconds ( 0.5 %)\n", - "camera_3_progress (00:00:02): 4 / 918 seconds ( 0.4 %)\n", - "camera_0_progress (00:00:02): 5 / 919 seconds ( 0.5 %)\n", - "camera_2_progress (00:00:02): 5 / 918 seconds ( 0.5 %)\n", - "camera_2_progress (00:00:03): 8 / 918 seconds ( 0.9 %)\n", - "camera_1_progress (00:00:03): 8 / 918 seconds ( 0.9 %)\n", - "camera_3_progress (00:00:03): 8 / 918 seconds ( 0.9 %)\n", - "camera_0_progress (00:00:03): 9 / 919 seconds ( 1.0 %)\n", - "camera_0_progress (00:00:04): 12 / 919 seconds ( 1.3 %)\n", - "camera_2_progress (00:00:04): 11 / 918 seconds ( 1.2 %)\n", - "camera_1_progress (00:00:04): 12 / 918 seconds ( 1.3 %)\n", - "camera_3_progress (00:00:04): 11 / 918 seconds ( 1.2 %)\n", - "camera_0_progress (00:00:05): 15 / 919 seconds ( 1.6 %)\n", - "camera_2_progress (00:00:05): 15 / 918 seconds ( 1.6 %)\n", - "camera_1_progress (00:00:05): 15 / 918 seconds ( 1.6 %)\n", - "camera_3_progress (00:00:05): 14 / 918 seconds ( 1.5 %)\n", - "camera_0_progress (00:00:06): 19 / 919 seconds ( 2.1 %)\n", - "camera_2_progress (00:00:06): 18 / 918 seconds ( 2.0 %)\n", - "camera_1_progress (00:00:06): 18 / 918 seconds ( 2.0 %)\n", - "camera_3_progress (00:00:06): 18 / 918 seconds ( 2.0 %)\n", - "camera_3_progress (00:00:07): 21 / 918 seconds ( 2.3 %)\n", - "camera_0_progress (00:00:07): 22 / 919 seconds ( 2.4 %)\n", - "camera_2_progress (00:00:07): 21 / 918 seconds ( 2.3 %)\n", - "camera_1_progress (00:00:07): 21 / 918 seconds ( 2.3 %)\n", - "camera_1_progress (00:00:08): 25 / 918 seconds ( 2.7 %)\n", - "camera_3_progress (00:00:08): 24 / 918 seconds ( 2.6 %)\n", - "camera_0_progress (00:00:08): 25 / 919 seconds ( 2.7 %)\n", - "camera_2_progress (00:00:08): 24 / 918 seconds ( 2.6 %)\n", - "camera_0_progress (00:00:09): 28 / 919 seconds ( 3.0 %)\n", - "camera_2_progress (00:00:09): 28 / 918 seconds ( 3.1 %)\n", - "camera_1_progress (00:00:09): 28 / 918 seconds ( 3.1 %)\n", - "camera_3_progress (00:00:09): 28 / 918 seconds ( 3.1 %)\n", - "camera_0_progress (00:00:10): 32 / 919 seconds ( 3.5 %)\n", - "camera_2_progress (00:00:10): 31 / 918 seconds ( 3.4 %)\n", - "camera_1_progress (00:00:10): 32 / 918 seconds ( 3.5 %)\n", - "camera_3_progress (00:00:10): 31 / 918 seconds ( 3.4 %)\n", - "camera_0_progress (00:00:11): 35 / 919 seconds ( 3.8 %)\n", - "camera_2_progress (00:00:11): 35 / 918 seconds ( 3.8 %)\n", - "camera_1_progress (00:00:11): 35 / 918 seconds ( 3.8 %)\n", - "camera_3_progress (00:00:11): 34 / 918 seconds ( 3.7 %)\n", - "camera_2_progress (00:00:12): 38 / 918 seconds ( 4.1 %)\n", - "camera_1_progress (00:00:12): 38 / 918 seconds ( 4.1 %)\n", - "camera_3_progress (00:00:12): 38 / 918 seconds ( 4.1 %)\n", - "camera_0_progress (00:00:12): 39 / 919 seconds ( 4.2 %)\n", - "camera_1_progress (00:00:13): 41 / 918 seconds ( 4.5 %)\n", - "camera_3_progress (00:00:13): 41 / 918 seconds ( 4.5 %)\n", - "camera_0_progress (00:00:13): 42 / 919 seconds ( 4.6 %)\n", - "camera_2_progress (00:00:13): 41 / 918 seconds ( 4.5 %)\n", - "camera_1_progress (00:00:14): 45 / 918 seconds ( 4.9 %)\n", - "camera_3_progress (00:00:14): 44 / 918 seconds ( 4.8 %)\n", - "camera_0_progress (00:00:14): 45 / 919 seconds ( 4.9 %)\n", - "camera_2_progress (00:00:14): 44 / 918 seconds ( 4.8 %)\n", - "camera_2_progress (00:00:15): 48 / 918 seconds ( 5.2 %)\n", - "camera_1_progress (00:00:15): 48 / 918 seconds ( 5.2 %)\n", - "camera_3_progress (00:00:15): 47 / 918 seconds ( 5.1 %)\n", - "camera_0_progress (00:00:15): 48 / 919 seconds ( 5.2 %)\n", - "camera_0_progress (00:00:16): 51 / 919 seconds ( 5.5 %)\n", - "camera_2_progress (00:00:16): 51 / 918 seconds ( 5.6 %)\n", - "camera_1_progress (00:00:16): 51 / 918 seconds ( 5.6 %)\n", - "camera_3_progress (00:00:16): 50 / 918 seconds ( 5.4 %)\n", - "camera_2_progress (00:00:17): 53 / 918 seconds ( 5.8 %)\n", - "camera_1_progress (00:00:17): 54 / 918 seconds ( 5.9 %)\n", - "camera_3_progress (00:00:17): 53 / 918 seconds ( 5.8 %)\n", - "camera_0_progress (00:00:17): 54 / 919 seconds ( 5.9 %)\n", - "camera_3_progress (00:00:18): 56 / 918 seconds ( 6.1 %)\n", - "camera_0_progress (00:00:18): 57 / 919 seconds ( 6.2 %)\n", - "camera_2_progress (00:00:18): 56 / 918 seconds ( 6.1 %)\n", - "camera_1_progress (00:00:18): 56 / 918 seconds ( 6.1 %)\n", - "camera_2_progress (00:00:19): 58 / 918 seconds ( 6.3 %)\n", - "camera_1_progress (00:00:19): 59 / 918 seconds ( 6.4 %)\n", - "camera_3_progress (00:00:19): 58 / 918 seconds ( 6.3 %)\n", - "camera_0_progress (00:00:19): 59 / 919 seconds ( 6.4 %)\n", - "camera_2_progress (00:00:20): 61 / 918 seconds ( 6.6 %)\n", - "camera_1_progress (00:00:20): 61 / 918 seconds ( 6.6 %)\n", - "camera_3_progress (00:00:20): 61 / 918 seconds ( 6.6 %)\n", - "camera_0_progress (00:00:20): 62 / 919 seconds ( 6.7 %)\n", - "camera_2_progress (00:00:21): 63 / 918 seconds ( 6.9 %)\n", - "camera_1_progress (00:00:21): 64 / 918 seconds ( 7.0 %)\n", - "camera_3_progress (00:00:21): 63 / 918 seconds ( 6.9 %)\n", - "camera_0_progress (00:00:21): 64 / 919 seconds ( 7.0 %)\n", - "camera_0_progress (00:00:22): 67 / 919 seconds ( 7.3 %)\n", - "camera_2_progress (00:00:22): 66 / 918 seconds ( 7.2 %)\n", - "camera_1_progress (00:00:22): 66 / 918 seconds ( 7.2 %)\n", - "camera_3_progress (00:00:22): 66 / 918 seconds ( 7.2 %)\n", - "camera_3_progress (00:00:23): 68 / 918 seconds ( 7.4 %)\n", - "camera_0_progress (00:00:23): 69 / 919 seconds ( 7.5 %)\n", - "camera_2_progress (00:00:23): 69 / 918 seconds ( 7.5 %)\n", - "camera_1_progress (00:00:23): 69 / 918 seconds ( 7.5 %)\n", - "camera_3_progress (00:00:24): 71 / 918 seconds ( 7.7 %)\n", - "camera_0_progress (00:00:24): 72 / 919 seconds ( 7.8 %)\n", - "camera_2_progress (00:00:24): 71 / 918 seconds ( 7.7 %)\n", - "camera_1_progress (00:00:24): 71 / 918 seconds ( 7.7 %)\n", - "camera_0_progress (00:00:25): 74 / 919 seconds ( 8.1 %)\n", - "camera_2_progress (00:00:25): 74 / 918 seconds ( 8.1 %)\n", - "camera_1_progress (00:00:25): 74 / 918 seconds ( 8.1 %)\n", - "camera_3_progress (00:00:25): 73 / 918 seconds ( 8.0 %)\n", - "camera_2_progress (00:00:26): 76 / 918 seconds ( 8.3 %)\n", - "camera_1_progress (00:00:26): 76 / 918 seconds ( 8.3 %)\n", - "camera_3_progress (00:00:26): 76 / 918 seconds ( 8.3 %)\n", - "camera_0_progress (00:00:26): 77 / 919 seconds ( 8.4 %)\n", - "camera_2_progress (00:00:27): 79 / 918 seconds ( 8.6 %)\n", - "camera_1_progress (00:00:27): 79 / 918 seconds ( 8.6 %)\n", - "camera_3_progress (00:00:27): 78 / 918 seconds ( 8.5 %)\n", - "camera_0_progress (00:00:27): 79 / 919 seconds ( 8.6 %)\n", - "camera_1_progress (00:00:28): 82 / 918 seconds ( 8.9 %)\n", - "camera_3_progress (00:00:28): 81 / 918 seconds ( 8.8 %)\n", - "camera_0_progress (00:00:28): 82 / 919 seconds ( 8.9 %)\n", - "camera_2_progress (00:00:28): 81 / 918 seconds ( 8.8 %)\n", - "camera_1_progress (00:00:29): 84 / 918 seconds ( 9.2 %)\n", - "camera_3_progress (00:00:29): 84 / 918 seconds ( 9.2 %)\n", - "camera_0_progress (00:00:29): 85 / 919 seconds ( 9.2 %)\n", - "camera_2_progress (00:00:29): 84 / 918 seconds ( 9.2 %)\n", - "camera_3_progress (00:00:30): 87 / 918 seconds ( 9.5 %)\n", - "camera_0_progress (00:00:30): 88 / 919 seconds ( 9.6 %)\n", - "camera_2_progress (00:00:30): 87 / 918 seconds ( 9.5 %)\n", - "camera_1_progress (00:00:30): 87 / 918 seconds ( 9.5 %)\n", - "camera_2_progress (00:00:31): 89 / 918 seconds ( 9.7 %)\n", - "camera_1_progress (00:00:31): 89 / 918 seconds ( 9.7 %)\n", - "camera_3_progress (00:00:31): 89 / 918 seconds ( 9.7 %)\n", - "camera_0_progress (00:00:31): 90 / 919 seconds ( 9.8 %)\n", - "camera_0_progress (00:00:32): 92 / 919 seconds (10.0 %)\n", - "camera_2_progress (00:00:32): 92 / 918 seconds (10.0 %)\n", - "camera_1_progress (00:00:32): 92 / 918 seconds (10.0 %)\n", - "camera_3_progress (00:00:32): 91 / 918 seconds ( 9.9 %)\n", - "camera_0_progress (00:00:33): 95 / 919 seconds (10.3 %)\n", - "camera_2_progress (00:00:33): 94 / 918 seconds (10.2 %)\n", - "camera_1_progress (00:00:33): 95 / 918 seconds (10.3 %)\n", - "camera_3_progress (00:00:33): 94 / 918 seconds (10.2 %)\n", - "camera_3_progress (00:00:34): 96 / 918 seconds (10.5 %)\n", - "camera_0_progress (00:00:34): 97 / 919 seconds (10.6 %)\n", - "camera_2_progress (00:00:34): 97 / 918 seconds (10.6 %)\n", - "camera_1_progress (00:00:34): 97 / 918 seconds (10.6 %)\n", - "camera_3_progress (00:00:35): 99 / 918 seconds (10.8 %)\n", - "camera_0_progress (00:00:35): 100 / 919 seconds (10.9 %)\n", - "camera_2_progress (00:00:35): 99 / 918 seconds (10.8 %)\n", - "camera_1_progress (00:00:35): 100 / 918 seconds (10.9 %)\n", - "camera_0_progress (00:00:36): 103 / 919 seconds (11.2 %)\n", - "camera_2_progress (00:00:36): 102 / 918 seconds (11.1 %)\n", - "camera_1_progress (00:00:36): 102 / 918 seconds (11.1 %)\n", - "camera_3_progress (00:00:36): 102 / 918 seconds (11.1 %)\n", - "camera_0_progress (00:00:37): 105 / 919 seconds (11.4 %)\n", - "camera_2_progress (00:00:37): 105 / 918 seconds (11.4 %)\n", - "camera_1_progress (00:00:37): 105 / 918 seconds (11.4 %)\n", - "camera_3_progress (00:00:37): 105 / 918 seconds (11.4 %)\n", - "camera_3_progress (00:00:38): 107 / 918 seconds (11.7 %)\n", - "camera_0_progress (00:00:38): 108 / 919 seconds (11.8 %)\n", - "camera_2_progress (00:00:38): 108 / 918 seconds (11.8 %)\n", - "camera_1_progress (00:00:38): 108 / 918 seconds (11.8 %)\n", - "camera_0_progress (00:00:39): 111 / 919 seconds (12.1 %)\n", - "camera_2_progress (00:00:39): 110 / 918 seconds (12.0 %)\n", - "camera_1_progress (00:00:39): 111 / 918 seconds (12.1 %)\n", - "camera_3_progress (00:00:39): 110 / 918 seconds (12.0 %)\n", - "camera_0_progress (00:00:40): 114 / 919 seconds (12.4 %)\n", - "camera_2_progress (00:00:40): 113 / 918 seconds (12.3 %)\n", - "camera_1_progress (00:00:40): 113 / 918 seconds (12.3 %)\n", - "camera_3_progress (00:00:40): 113 / 918 seconds (12.3 %)\n", - "camera_1_progress (00:00:41): 116 / 918 seconds (12.6 %)\n", - "camera_3_progress (00:00:41): 115 / 918 seconds (12.5 %)\n", - "camera_0_progress (00:00:41): 116 / 919 seconds (12.6 %)\n", - "camera_2_progress (00:00:41): 116 / 918 seconds (12.6 %)\n", - "camera_2_progress (00:00:42): 118 / 918 seconds (12.9 %)\n", - "camera_1_progress (00:00:42): 119 / 918 seconds (13.0 %)\n", - "camera_3_progress (00:00:42): 118 / 918 seconds (12.9 %)\n", - "camera_0_progress (00:00:42): 119 / 919 seconds (12.9 %)\n", - "camera_1_progress (00:00:43): 121 / 918 seconds (13.2 %)\n", - "camera_3_progress (00:00:43): 121 / 918 seconds (13.2 %)\n", - "camera_0_progress (00:00:43): 122 / 919 seconds (13.3 %)\n", - "camera_2_progress (00:00:43): 121 / 918 seconds (13.2 %)\n", - "camera_1_progress (00:00:44): 124 / 918 seconds (13.5 %)\n", - "camera_3_progress (00:00:44): 124 / 918 seconds (13.5 %)\n", - "camera_0_progress (00:00:44): 125 / 919 seconds (13.6 %)\n", - "camera_2_progress (00:00:44): 124 / 918 seconds (13.5 %)\n", - "camera_2_progress (00:00:45): 127 / 918 seconds (13.8 %)\n", - "camera_1_progress (00:00:45): 127 / 918 seconds (13.8 %)\n", - "camera_3_progress (00:00:45): 126 / 918 seconds (13.7 %)\n", - "camera_0_progress (00:00:45): 127 / 919 seconds (13.8 %)\n", - "camera_0_progress (00:00:46): 130 / 919 seconds (14.1 %)\n", - "camera_2_progress (00:00:46): 129 / 918 seconds (14.1 %)\n", - "camera_1_progress (00:00:46): 130 / 918 seconds (14.2 %)\n", - "camera_3_progress (00:00:46): 129 / 918 seconds (14.1 %)\n", - "camera_0_progress (00:00:47): 133 / 919 seconds (14.5 %)\n", - "camera_2_progress (00:00:47): 132 / 918 seconds (14.4 %)\n", - "camera_1_progress (00:00:47): 132 / 918 seconds (14.4 %)\n", - "camera_3_progress (00:00:47): 132 / 918 seconds (14.4 %)\n", - "camera_1_progress (00:00:48): 135 / 918 seconds (14.7 %)\n", - "camera_3_progress (00:00:48): 134 / 918 seconds (14.6 %)\n", - "camera_0_progress (00:00:48): 135 / 919 seconds (14.7 %)\n", - "camera_2_progress (00:00:48): 135 / 918 seconds (14.7 %)\n", - "camera_3_progress (00:00:49): 137 / 918 seconds (14.9 %)\n", - "camera_0_progress (00:00:49): 138 / 919 seconds (15.0 %)\n", - "camera_2_progress (00:00:49): 138 / 918 seconds (15.0 %)\n", - "camera_1_progress (00:00:49): 138 / 918 seconds (15.0 %)\n", - "camera_0_progress (00:00:50): 141 / 919 seconds (15.3 %)\n", - "camera_2_progress (00:00:50): 140 / 918 seconds (15.3 %)\n", - "camera_1_progress (00:00:50): 141 / 918 seconds (15.4 %)\n", - "camera_3_progress (00:00:50): 140 / 918 seconds (15.3 %)\n", - "camera_2_progress (00:00:51): 143 / 918 seconds (15.6 %)\n", - "camera_1_progress (00:00:51): 143 / 918 seconds (15.6 %)\n", - "camera_3_progress (00:00:51): 143 / 918 seconds (15.6 %)\n", - "camera_0_progress (00:00:51): 144 / 919 seconds (15.7 %)\n", - "camera_3_progress (00:00:52): 145 / 918 seconds (15.8 %)\n", - "camera_0_progress (00:00:52): 146 / 919 seconds (15.9 %)\n", - "camera_2_progress (00:00:52): 146 / 918 seconds (15.9 %)\n", - "camera_1_progress (00:00:52): 146 / 918 seconds (15.9 %)\n", - "camera_2_progress (00:00:53): 148 / 918 seconds (16.1 %)\n", - "camera_1_progress (00:00:53): 149 / 918 seconds (16.2 %)\n", - "camera_3_progress (00:00:53): 148 / 918 seconds (16.1 %)\n", - "camera_0_progress (00:00:53): 149 / 919 seconds (16.2 %)\n", - "camera_1_progress (00:00:54): 151 / 918 seconds (16.4 %)\n", - "camera_3_progress (00:00:54): 151 / 918 seconds (16.4 %)\n", - "camera_0_progress (00:00:54): 152 / 919 seconds (16.5 %)\n", - "camera_2_progress (00:00:54): 151 / 918 seconds (16.4 %)\n", - "camera_1_progress (00:00:55): 154 / 918 seconds (16.8 %)\n", - "camera_3_progress (00:00:55): 154 / 918 seconds (16.8 %)\n", - "camera_0_progress (00:00:55): 155 / 919 seconds (16.9 %)\n", - "camera_2_progress (00:00:55): 154 / 918 seconds (16.8 %)\n", - "camera_3_progress (00:00:56): 156 / 918 seconds (17.0 %)\n", - "camera_0_progress (00:00:56): 157 / 919 seconds (17.1 %)\n", - "camera_2_progress (00:00:56): 157 / 918 seconds (17.1 %)\n", - "camera_1_progress (00:00:56): 157 / 918 seconds (17.1 %)\n", - "camera_0_progress (00:00:57): 160 / 919 seconds (17.4 %)\n", - "camera_2_progress (00:00:57): 159 / 918 seconds (17.3 %)\n", - "camera_1_progress (00:00:57): 160 / 918 seconds (17.4 %)\n", - "camera_3_progress (00:00:57): 159 / 918 seconds (17.3 %)\n", - "camera_1_progress (00:00:58): 162 / 918 seconds (17.6 %)\n", - "camera_3_progress (00:00:58): 162 / 918 seconds (17.6 %)\n", - "camera_0_progress (00:00:58): 163 / 919 seconds (17.7 %)\n", - "camera_2_progress (00:00:58): 162 / 918 seconds (17.6 %)\n", - "camera_2_progress (00:00:59): 165 / 918 seconds (18.0 %)\n", - "camera_1_progress (00:00:59): 165 / 918 seconds (18.0 %)\n", - "camera_3_progress (00:00:59): 164 / 918 seconds (17.9 %)\n", - "camera_0_progress (00:00:59): 165 / 919 seconds (18.0 %)\n", - "camera_2_progress (00:01:00): 167 / 918 seconds (18.2 %)\n", - "camera_1_progress (00:01:00): 168 / 918 seconds (18.3 %)\n", - "camera_3_progress (00:01:00): 167 / 918 seconds (18.2 %)\n", - "camera_0_progress (00:01:00): 168 / 919 seconds (18.3 %)\n", - "camera_1_progress (00:01:01): 171 / 918 seconds (18.6 %)\n", - "camera_3_progress (00:01:01): 170 / 918 seconds (18.5 %)\n", - "camera_0_progress (00:01:01): 171 / 919 seconds (18.6 %)\n", - "camera_2_progress (00:01:01): 170 / 918 seconds (18.5 %)\n", - "camera_3_progress (00:01:02): 173 / 918 seconds (18.8 %)\n", - "camera_0_progress (00:01:02): 174 / 919 seconds (18.9 %)\n", - "camera_2_progress (00:01:02): 173 / 918 seconds (18.8 %)\n", - "camera_1_progress (00:01:02): 173 / 918 seconds (18.8 %)\n", - "camera_1_progress (00:01:03): 176 / 918 seconds (19.2 %)\n", - "camera_3_progress (00:01:03): 175 / 918 seconds (19.1 %)\n", - "camera_0_progress (00:01:03): 176 / 919 seconds (19.2 %)\n", - "camera_2_progress (00:01:03): 176 / 918 seconds (19.2 %)\n", - "camera_0_progress (00:01:04): 179 / 919 seconds (19.5 %)\n", - "camera_2_progress (00:01:04): 178 / 918 seconds (19.4 %)\n", - "camera_1_progress (00:01:04): 179 / 918 seconds (19.5 %)\n", - "camera_3_progress (00:01:04): 178 / 918 seconds (19.4 %)\n", - "camera_0_progress (00:01:05): 182 / 919 seconds (19.8 %)\n", - "camera_2_progress (00:01:05): 181 / 918 seconds (19.7 %)\n", - "camera_1_progress (00:01:05): 181 / 918 seconds (19.7 %)\n", - "camera_3_progress (00:01:05): 181 / 918 seconds (19.7 %)\n", - "camera_0_progress (00:01:06): 184 / 919 seconds (20.0 %)\n", - "camera_2_progress (00:01:06): 184 / 918 seconds (20.0 %)\n", - "camera_1_progress (00:01:06): 184 / 918 seconds (20.0 %)\n", - "camera_3_progress (00:01:06): 183 / 918 seconds (19.9 %)\n", - "camera_2_progress (00:01:07): 186 / 918 seconds (20.3 %)\n", - "camera_1_progress (00:01:07): 187 / 918 seconds (20.4 %)\n", - "camera_3_progress (00:01:07): 186 / 918 seconds (20.3 %)\n", - "camera_0_progress (00:01:07): 187 / 919 seconds (20.3 %)\n", - "camera_3_progress (00:01:08): 189 / 918 seconds (20.6 %)\n", - "camera_0_progress (00:01:08): 190 / 919 seconds (20.7 %)\n", - "camera_2_progress (00:01:08): 189 / 918 seconds (20.6 %)\n", - "camera_1_progress (00:01:08): 190 / 918 seconds (20.7 %)\n", - "camera_3_progress (00:01:09): 192 / 918 seconds (20.9 %)\n", - "camera_0_progress (00:01:09): 193 / 919 seconds (21.0 %)\n", - "camera_2_progress (00:01:09): 192 / 918 seconds (20.9 %)\n", - "camera_1_progress (00:01:09): 192 / 918 seconds (20.9 %)\n", - "camera_3_progress (00:01:10): 194 / 918 seconds (21.1 %)\n", - "camera_0_progress (00:01:10): 195 / 919 seconds (21.2 %)\n", - "camera_2_progress (00:01:10): 195 / 918 seconds (21.2 %)\n", - "camera_1_progress (00:01:10): 195 / 918 seconds (21.2 %)\n", - "camera_0_progress (00:01:11): 198 / 919 seconds (21.5 %)\n", - "camera_2_progress (00:01:11): 197 / 918 seconds (21.5 %)\n", - "camera_1_progress (00:01:11): 198 / 918 seconds (21.6 %)\n", - "camera_3_progress (00:01:11): 197 / 918 seconds (21.5 %)\n", - "camera_3_progress (00:01:12): 200 / 918 seconds (21.8 %)\n", - "camera_0_progress (00:01:12): 201 / 919 seconds (21.9 %)\n", - "camera_2_progress (00:01:12): 200 / 918 seconds (21.8 %)\n", - "camera_1_progress (00:01:12): 200 / 918 seconds (21.8 %)\n", - "camera_1_progress (00:01:13): 203 / 918 seconds (22.1 %)\n", - "camera_3_progress (00:01:13): 202 / 918 seconds (22.0 %)\n", - "camera_0_progress (00:01:13): 203 / 919 seconds (22.1 %)\n", - "camera_2_progress (00:01:13): 203 / 918 seconds (22.1 %)\n", - "camera_1_progress (00:01:14): 206 / 918 seconds (22.4 %)\n", - "camera_3_progress (00:01:14): 205 / 918 seconds (22.3 %)\n", - "camera_0_progress (00:01:14): 206 / 919 seconds (22.4 %)\n", - "camera_2_progress (00:01:14): 205 / 918 seconds (22.3 %)\n", - "camera_1_progress (00:01:15): 208 / 918 seconds (22.7 %)\n", - "camera_3_progress (00:01:15): 208 / 918 seconds (22.7 %)\n", - "camera_0_progress (00:01:15): 209 / 919 seconds (22.7 %)\n", - "camera_2_progress (00:01:15): 208 / 918 seconds (22.7 %)\n", - "camera_3_progress (00:01:16): 211 / 918 seconds (23.0 %)\n", - "camera_0_progress (00:01:16): 212 / 919 seconds (23.1 %)\n", - "camera_2_progress (00:01:16): 211 / 918 seconds (23.0 %)\n", - "camera_1_progress (00:01:16): 212 / 918 seconds (23.1 %)\n", - "camera_0_progress (00:01:17): 214 / 919 seconds (23.3 %)\n", - "camera_2_progress (00:01:17): 213 / 918 seconds (23.2 %)\n", - "camera_1_progress (00:01:17): 214 / 918 seconds (23.3 %)\n", - "camera_3_progress (00:01:17): 213 / 918 seconds (23.2 %)\n", - "camera_0_progress (00:01:18): 217 / 919 seconds (23.6 %)\n", - "camera_2_progress (00:01:18): 216 / 918 seconds (23.5 %)\n", - "camera_1_progress (00:01:18): 216 / 918 seconds (23.5 %)\n", - "camera_3_progress (00:01:18): 216 / 918 seconds (23.5 %)\n", - "camera_2_progress (00:01:19): 218 / 918 seconds (23.7 %)\n", - "camera_1_progress (00:01:19): 219 / 918 seconds (23.9 %)\n", - "camera_3_progress (00:01:19): 218 / 918 seconds (23.7 %)\n", - "camera_0_progress (00:01:19): 219 / 919 seconds (23.8 %)\n", - "camera_3_progress (00:01:20): 221 / 918 seconds (24.1 %)\n", - "camera_0_progress (00:01:20): 222 / 919 seconds (24.2 %)\n", - "camera_2_progress (00:01:20): 221 / 918 seconds (24.1 %)\n", - "camera_1_progress (00:01:20): 221 / 918 seconds (24.1 %)\n", - "camera_1_progress (00:01:21): 224 / 918 seconds (24.4 %)\n", - "camera_3_progress (00:01:21): 223 / 918 seconds (24.3 %)\n", - "camera_0_progress (00:01:21): 224 / 919 seconds (24.4 %)\n", - "camera_2_progress (00:01:21): 224 / 918 seconds (24.4 %)\n", - "camera_2_progress (00:01:22): 226 / 918 seconds (24.6 %)\n", - "camera_1_progress (00:01:22): 227 / 918 seconds (24.7 %)\n", - "camera_3_progress (00:01:22): 226 / 918 seconds (24.6 %)\n", - "camera_0_progress (00:01:22): 227 / 919 seconds (24.7 %)\n", - "camera_0_progress (00:01:23): 230 / 919 seconds (25.0 %)\n", - "camera_2_progress (00:01:23): 229 / 918 seconds (24.9 %)\n", - "camera_1_progress (00:01:23): 229 / 918 seconds (24.9 %)\n", - "camera_3_progress (00:01:23): 229 / 918 seconds (24.9 %)\n", - "camera_1_progress (00:01:24): 232 / 918 seconds (25.3 %)\n", - "camera_3_progress (00:01:24): 231 / 918 seconds (25.2 %)\n", - "camera_0_progress (00:01:24): 232 / 919 seconds (25.2 %)\n", - "camera_2_progress (00:01:24): 232 / 918 seconds (25.3 %)\n", - "camera_2_progress (00:01:25): 234 / 918 seconds (25.5 %)\n", - "camera_1_progress (00:01:25): 234 / 918 seconds (25.5 %)\n", - "camera_3_progress (00:01:25): 234 / 918 seconds (25.5 %)\n", - "camera_0_progress (00:01:25): 235 / 919 seconds (25.6 %)\n", - "camera_0_progress (00:01:26): 237 / 919 seconds (25.8 %)\n", - "camera_2_progress (00:01:26): 237 / 918 seconds (25.8 %)\n", - "camera_1_progress (00:01:26): 237 / 918 seconds (25.8 %)\n", - "camera_3_progress (00:01:26): 236 / 918 seconds (25.7 %)\n", - "camera_1_progress (00:01:27): 240 / 918 seconds (26.1 %)\n", - "camera_3_progress (00:01:27): 239 / 918 seconds (26.0 %)\n", - "camera_0_progress (00:01:27): 240 / 919 seconds (26.1 %)\n", - "camera_2_progress (00:01:27): 239 / 918 seconds (26.0 %)\n", - "camera_2_progress (00:01:28): 242 / 918 seconds (26.4 %)\n", - "camera_1_progress (00:01:28): 242 / 918 seconds (26.4 %)\n", - "camera_3_progress (00:01:28): 242 / 918 seconds (26.4 %)\n", - "camera_0_progress (00:01:28): 243 / 919 seconds (26.4 %)\n", - "camera_2_progress (00:01:29): 244 / 918 seconds (26.6 %)\n", - "camera_1_progress (00:01:29): 245 / 918 seconds (26.7 %)\n", - "camera_3_progress (00:01:29): 244 / 918 seconds (26.6 %)\n", - "camera_0_progress (00:01:29): 245 / 919 seconds (26.7 %)\n", - "camera_0_progress (00:01:30): 248 / 919 seconds (27.0 %)\n", - "camera_2_progress (00:01:30): 247 / 918 seconds (26.9 %)\n", - "camera_1_progress (00:01:30): 247 / 918 seconds (26.9 %)\n", - "camera_3_progress (00:01:30): 247 / 918 seconds (26.9 %)\n", - "camera_2_progress (00:01:31): 250 / 918 seconds (27.2 %)\n", - "camera_1_progress (00:01:31): 250 / 918 seconds (27.2 %)\n", - "camera_3_progress (00:01:31): 249 / 918 seconds (27.1 %)\n", - "camera_0_progress (00:01:31): 250 / 919 seconds (27.2 %)\n", - "camera_2_progress (00:01:32): 252 / 918 seconds (27.5 %)\n", - "camera_1_progress (00:01:32): 252 / 918 seconds (27.5 %)\n", - "camera_3_progress (00:01:32): 252 / 918 seconds (27.5 %)\n", - "camera_0_progress (00:01:32): 253 / 919 seconds (27.5 %)\n", - "camera_3_progress (00:01:33): 255 / 918 seconds (27.8 %)\n", - "camera_0_progress (00:01:33): 256 / 919 seconds (27.9 %)\n", - "camera_2_progress (00:01:33): 255 / 918 seconds (27.8 %)\n", - "camera_1_progress (00:01:33): 255 / 918 seconds (27.8 %)\n", - "camera_3_progress (00:01:34): 257 / 918 seconds (28.0 %)\n", - "camera_0_progress (00:01:34): 258 / 919 seconds (28.1 %)\n", - "camera_2_progress (00:01:34): 258 / 918 seconds (28.1 %)\n", - "camera_1_progress (00:01:34): 258 / 918 seconds (28.1 %)\n", - "camera_3_progress (00:01:35): 260 / 918 seconds (28.3 %)\n", - "camera_0_progress (00:01:35): 261 / 919 seconds (28.4 %)\n", - "camera_2_progress (00:01:35): 260 / 918 seconds (28.3 %)\n", - "camera_1_progress (00:01:35): 260 / 918 seconds (28.3 %)\n", - "camera_3_progress (00:01:36): 262 / 918 seconds (28.5 %)\n", - "camera_0_progress (00:01:36): 263 / 919 seconds (28.6 %)\n", - "camera_2_progress (00:01:36): 263 / 918 seconds (28.6 %)\n", - "camera_1_progress (00:01:36): 263 / 918 seconds (28.6 %)\n", - "camera_2_progress (00:01:37): 265 / 918 seconds (28.9 %)\n", - "camera_1_progress (00:01:37): 265 / 918 seconds (28.9 %)\n", - "camera_3_progress (00:01:37): 265 / 918 seconds (28.9 %)\n", - "camera_0_progress (00:01:37): 266 / 919 seconds (28.9 %)\n", - "camera_0_progress (00:01:38): 269 / 919 seconds (29.3 %)\n", - "camera_2_progress (00:01:38): 268 / 918 seconds (29.2 %)\n", - "camera_1_progress (00:01:38): 268 / 918 seconds (29.2 %)\n", - "camera_3_progress (00:01:38): 268 / 918 seconds (29.2 %)\n", - "camera_2_progress (00:01:39): 270 / 918 seconds (29.4 %)\n", - "camera_1_progress (00:01:39): 271 / 918 seconds (29.5 %)\n", - "camera_3_progress (00:01:39): 270 / 918 seconds (29.4 %)\n", - "camera_0_progress (00:01:39): 271 / 919 seconds (29.5 %)\n", - "camera_1_progress (00:01:40): 273 / 918 seconds (29.7 %)\n", - "camera_3_progress (00:01:40): 272 / 918 seconds (29.6 %)\n", - "camera_0_progress (00:01:40): 273 / 919 seconds (29.7 %)\n", - "camera_2_progress (00:01:40): 273 / 918 seconds (29.7 %)\n", - "camera_0_progress (00:01:41): 276 / 919 seconds (30.0 %)\n", - "camera_2_progress (00:01:41): 275 / 918 seconds (30.0 %)\n", - "camera_1_progress (00:01:41): 275 / 918 seconds (30.0 %)\n", - "camera_3_progress (00:01:41): 275 / 918 seconds (30.0 %)\n", - "camera_3_progress (00:01:42): 278 / 918 seconds (30.3 %)\n", - "camera_0_progress (00:01:42): 279 / 919 seconds (30.4 %)\n", - "camera_2_progress (00:01:42): 278 / 918 seconds (30.3 %)\n", - "camera_1_progress (00:01:42): 278 / 918 seconds (30.3 %)\n", - "camera_2_progress (00:01:43): 280 / 918 seconds (30.5 %)\n", - "camera_1_progress (00:01:43): 281 / 918 seconds (30.6 %)\n", - "camera_3_progress (00:01:43): 280 / 918 seconds (30.5 %)\n", - "camera_0_progress (00:01:43): 281 / 919 seconds (30.6 %)\n", - "camera_3_progress (00:01:44): 283 / 918 seconds (30.8 %)\n", - "camera_0_progress (00:01:44): 284 / 919 seconds (30.9 %)\n", - "camera_2_progress (00:01:44): 283 / 918 seconds (30.8 %)\n", - "camera_1_progress (00:01:44): 283 / 918 seconds (30.8 %)\n", - "camera_3_progress (00:01:45): 286 / 918 seconds (31.2 %)\n", - "camera_0_progress (00:01:45): 287 / 919 seconds (31.2 %)\n", - "camera_2_progress (00:01:45): 286 / 918 seconds (31.2 %)\n", - "camera_1_progress (00:01:45): 286 / 918 seconds (31.2 %)\n", - "camera_1_progress (00:01:46): 288 / 918 seconds (31.4 %)\n", - "camera_3_progress (00:01:46): 288 / 918 seconds (31.4 %)\n", - "camera_0_progress (00:01:46): 289 / 919 seconds (31.4 %)\n", - "camera_2_progress (00:01:46): 288 / 918 seconds (31.4 %)\n", - "camera_2_progress (00:01:47): 291 / 918 seconds (31.7 %)\n", - "camera_1_progress (00:01:47): 291 / 918 seconds (31.7 %)\n", - "camera_3_progress (00:01:47): 290 / 918 seconds (31.6 %)\n", - "camera_0_progress (00:01:47): 291 / 919 seconds (31.7 %)\n", - "camera_0_progress (00:01:48): 294 / 919 seconds (32.0 %)\n", - "camera_2_progress (00:01:48): 293 / 918 seconds (31.9 %)\n", - "camera_1_progress (00:01:48): 294 / 918 seconds (32.0 %)\n", - "camera_3_progress (00:01:48): 293 / 918 seconds (31.9 %)\n", - "camera_2_progress (00:01:49): 296 / 918 seconds (32.2 %)\n", - "camera_1_progress (00:01:49): 296 / 918 seconds (32.2 %)\n", - "camera_3_progress (00:01:49): 296 / 918 seconds (32.2 %)\n", - "camera_0_progress (00:01:49): 297 / 919 seconds (32.3 %)\n", - "camera_3_progress (00:01:50): 298 / 918 seconds (32.5 %)\n", - "camera_0_progress (00:01:50): 299 / 919 seconds (32.5 %)\n", - "camera_2_progress (00:01:50): 299 / 918 seconds (32.6 %)\n", - "camera_1_progress (00:01:50): 299 / 918 seconds (32.6 %)\n", - "camera_1_progress (00:01:51): 301 / 918 seconds (32.8 %)\n", - "camera_3_progress (00:01:51): 301 / 918 seconds (32.8 %)\n", - "camera_0_progress (00:01:51): 302 / 919 seconds (32.9 %)\n", - "camera_2_progress (00:01:51): 301 / 918 seconds (32.8 %)\n", - "camera_0_progress (00:01:52): 304 / 919 seconds (33.1 %)\n", - "camera_2_progress (00:01:52): 304 / 918 seconds (33.1 %)\n", - "camera_1_progress (00:01:52): 304 / 918 seconds (33.1 %)\n", - "camera_3_progress (00:01:52): 303 / 918 seconds (33.0 %)\n", - "camera_0_progress (00:01:53): 307 / 919 seconds (33.4 %)\n", - "camera_2_progress (00:01:53): 306 / 918 seconds (33.3 %)\n", - "camera_1_progress (00:01:53): 306 / 918 seconds (33.3 %)\n", - "camera_3_progress (00:01:53): 306 / 918 seconds (33.3 %)\n", - "camera_1_progress (00:01:54): 309 / 918 seconds (33.7 %)\n", - "camera_3_progress (00:01:54): 308 / 918 seconds (33.6 %)\n", - "camera_0_progress (00:01:54): 309 / 919 seconds (33.6 %)\n", - "camera_2_progress (00:01:54): 309 / 918 seconds (33.7 %)\n", - "camera_3_progress (00:01:55): 311 / 918 seconds (33.9 %)\n", - "camera_0_progress (00:01:55): 312 / 919 seconds (33.9 %)\n", - "camera_2_progress (00:01:55): 311 / 918 seconds (33.9 %)\n", - "camera_1_progress (00:01:55): 312 / 918 seconds (34.0 %)\n", - "camera_3_progress (00:01:56): 314 / 918 seconds (34.2 %)\n", - "camera_0_progress (00:01:56): 315 / 919 seconds (34.3 %)\n", - "camera_2_progress (00:01:56): 314 / 918 seconds (34.2 %)\n", - "camera_1_progress (00:01:56): 314 / 918 seconds (34.2 %)\n", - "camera_2_progress (00:01:57): 316 / 918 seconds (34.4 %)\n", - "camera_3_progress (00:01:57): 316 / 918 seconds (34.4 %)\n", - "camera_1_progress (00:01:57): 317 / 918 seconds (34.5 %)\n", - "camera_0_progress (00:01:57): 317 / 919 seconds (34.5 %)\n", - "camera_3_progress (00:01:58): 319 / 918 seconds (34.7 %)\n", - "camera_0_progress (00:01:58): 320 / 919 seconds (34.8 %)\n", - "camera_2_progress (00:01:58): 319 / 918 seconds (34.7 %)\n", - "camera_1_progress (00:01:58): 319 / 918 seconds (34.7 %)\n", - "camera_0_progress (00:01:59): 322 / 919 seconds (35.0 %)\n", - "camera_2_progress (00:01:59): 321 / 918 seconds (35.0 %)\n", - "camera_1_progress (00:01:59): 322 / 918 seconds (35.1 %)\n", - "camera_3_progress (00:01:59): 321 / 918 seconds (35.0 %)\n", - "camera_2_progress (00:02:00): 324 / 918 seconds (35.3 %)\n", - "camera_1_progress (00:02:00): 324 / 918 seconds (35.3 %)\n", - "camera_3_progress (00:02:00): 324 / 918 seconds (35.3 %)\n", - "camera_0_progress (00:02:00): 325 / 919 seconds (35.4 %)\n", - "camera_3_progress (00:02:01): 326 / 918 seconds (35.5 %)\n", - "camera_0_progress (00:02:01): 327 / 919 seconds (35.6 %)\n", - "camera_2_progress (00:02:01): 327 / 918 seconds (35.6 %)\n", - "camera_1_progress (00:02:01): 327 / 918 seconds (35.6 %)\n", - "camera_1_progress (00:02:02): 330 / 918 seconds (35.9 %)\n", - "camera_3_progress (00:02:02): 329 / 918 seconds (35.8 %)\n", - "camera_0_progress (00:02:02): 330 / 919 seconds (35.9 %)\n", - "camera_2_progress (00:02:02): 329 / 918 seconds (35.8 %)\n", - "camera_2_progress (00:02:03): 332 / 918 seconds (36.2 %)\n", - "camera_1_progress (00:02:03): 332 / 918 seconds (36.2 %)\n", - "camera_3_progress (00:02:03): 332 / 918 seconds (36.2 %)\n", - "camera_0_progress (00:02:03): 333 / 919 seconds (36.2 %)\n", - "camera_3_progress (00:02:04): 334 / 918 seconds (36.4 %)\n", - "camera_0_progress (00:02:04): 335 / 919 seconds (36.5 %)\n", - "camera_2_progress (00:02:04): 334 / 918 seconds (36.4 %)\n", - "camera_1_progress (00:02:04): 335 / 918 seconds (36.5 %)\n", - "camera_1_progress (00:02:05): 337 / 918 seconds (36.7 %)\n", - "camera_3_progress (00:02:05): 337 / 918 seconds (36.7 %)\n", - "camera_0_progress (00:02:05): 338 / 919 seconds (36.8 %)\n", - "camera_2_progress (00:02:05): 337 / 918 seconds (36.7 %)\n", - "camera_2_progress (00:02:06): 339 / 918 seconds (36.9 %)\n", - "camera_1_progress (00:02:06): 340 / 918 seconds (37.0 %)\n", - "camera_3_progress (00:02:06): 339 / 918 seconds (36.9 %)\n", - "camera_0_progress (00:02:06): 340 / 919 seconds (37.0 %)\n", - "camera_1_progress (00:02:07): 342 / 918 seconds (37.3 %)\n", - "camera_3_progress (00:02:07): 342 / 918 seconds (37.3 %)\n", - "camera_0_progress (00:02:07): 343 / 919 seconds (37.3 %)\n", - "camera_2_progress (00:02:07): 342 / 918 seconds (37.3 %)\n", - "camera_2_progress (00:02:08): 345 / 918 seconds (37.6 %)\n", - "camera_1_progress (00:02:08): 345 / 918 seconds (37.6 %)\n", - "camera_3_progress (00:02:08): 344 / 918 seconds (37.5 %)\n", - "camera_0_progress (00:02:08): 346 / 919 seconds (37.6 %)\n", - "camera_3_progress (00:02:09): 347 / 918 seconds (37.8 %)\n", - "camera_0_progress (00:02:09): 348 / 919 seconds (37.9 %)\n", - "camera_2_progress (00:02:09): 347 / 918 seconds (37.8 %)\n", - "camera_1_progress (00:02:09): 348 / 918 seconds (37.9 %)\n", - "camera_1_progress (00:02:10): 350 / 918 seconds (38.1 %)\n", - "camera_3_progress (00:02:10): 350 / 918 seconds (38.1 %)\n", - "camera_0_progress (00:02:10): 351 / 919 seconds (38.2 %)\n", - "camera_2_progress (00:02:10): 350 / 918 seconds (38.1 %)\n", - "camera_2_progress (00:02:11): 353 / 918 seconds (38.5 %)\n", - "camera_1_progress (00:02:11): 353 / 918 seconds (38.5 %)\n", - "camera_3_progress (00:02:11): 352 / 918 seconds (38.3 %)\n", - "camera_0_progress (00:02:11): 353 / 919 seconds (38.4 %)\n", - "camera_3_progress (00:02:12): 355 / 918 seconds (38.7 %)\n", - "camera_0_progress (00:02:12): 356 / 919 seconds (38.7 %)\n", - "camera_2_progress (00:02:12): 355 / 918 seconds (38.7 %)\n", - "camera_1_progress (00:02:12): 356 / 918 seconds (38.8 %)\n", - "camera_0_progress (00:02:13): 358 / 919 seconds (39.0 %)\n", - "camera_2_progress (00:02:13): 358 / 918 seconds (39.0 %)\n", - "camera_1_progress (00:02:13): 358 / 918 seconds (39.0 %)\n", - "camera_3_progress (00:02:13): 357 / 918 seconds (38.9 %)\n", - "camera_3_progress (00:02:14): 360 / 918 seconds (39.2 %)\n", - "camera_0_progress (00:02:14): 361 / 919 seconds (39.3 %)\n", - "camera_2_progress (00:02:14): 360 / 918 seconds (39.2 %)\n", - "camera_1_progress (00:02:14): 361 / 918 seconds (39.3 %)\n", - "camera_3_progress (00:02:15): 362 / 918 seconds (39.4 %)\n", - "camera_0_progress (00:02:15): 363 / 919 seconds (39.5 %)\n", - "camera_2_progress (00:02:15): 363 / 918 seconds (39.5 %)\n", - "camera_1_progress (00:02:15): 363 / 918 seconds (39.5 %)\n", - "camera_1_progress (00:02:16): 366 / 918 seconds (39.9 %)\n", - "camera_3_progress (00:02:16): 365 / 918 seconds (39.8 %)\n", - "camera_0_progress (00:02:16): 366 / 919 seconds (39.8 %)\n", - "camera_2_progress (00:02:16): 365 / 918 seconds (39.8 %)\n", - "camera_2_progress (00:02:17): 368 / 918 seconds (40.1 %)\n", - "camera_1_progress (00:02:17): 368 / 918 seconds (40.1 %)\n", - "camera_3_progress (00:02:17): 368 / 918 seconds (40.1 %)\n", - "camera_0_progress (00:02:17): 369 / 919 seconds (40.2 %)\n", - "camera_2_progress (00:02:18): 371 / 918 seconds (40.4 %)\n", - "camera_1_progress (00:02:18): 371 / 918 seconds (40.4 %)\n", - "camera_3_progress (00:02:18): 370 / 918 seconds (40.3 %)\n", - "camera_0_progress (00:02:18): 371 / 919 seconds (40.4 %)\n", - "camera_3_progress (00:02:19): 373 / 918 seconds (40.6 %)\n", - "camera_0_progress (00:02:19): 374 / 919 seconds (40.7 %)\n", - "camera_2_progress (00:02:19): 373 / 918 seconds (40.6 %)\n", - "camera_1_progress (00:02:19): 373 / 918 seconds (40.6 %)\n", - "camera_1_progress (00:02:20): 376 / 918 seconds (41.0 %)\n", - "camera_3_progress (00:02:20): 375 / 918 seconds (40.8 %)\n", - "camera_0_progress (00:02:20): 376 / 919 seconds (40.9 %)\n", - "camera_2_progress (00:02:20): 375 / 918 seconds (40.8 %)\n", - "camera_2_progress (00:02:21): 378 / 918 seconds (41.2 %)\n", - "camera_1_progress (00:02:21): 378 / 918 seconds (41.2 %)\n", - "camera_3_progress (00:02:21): 378 / 918 seconds (41.2 %)\n", - "camera_0_progress (00:02:21): 379 / 919 seconds (41.2 %)\n", - "camera_3_progress (00:02:22): 380 / 918 seconds (41.4 %)\n", - "camera_0_progress (00:02:22): 381 / 919 seconds (41.5 %)\n", - "camera_2_progress (00:02:22): 381 / 918 seconds (41.5 %)\n", - "camera_1_progress (00:02:22): 381 / 918 seconds (41.5 %)\n", - "camera_1_progress (00:02:23): 384 / 918 seconds (41.8 %)\n", - "camera_3_progress (00:02:23): 383 / 918 seconds (41.7 %)\n", - "camera_0_progress (00:02:23): 384 / 919 seconds (41.8 %)\n", - "camera_2_progress (00:02:23): 383 / 918 seconds (41.7 %)\n", - "camera_3_progress (00:02:24): 385 / 918 seconds (41.9 %)\n", - "camera_0_progress (00:02:24): 386 / 919 seconds (42.0 %)\n", - "camera_2_progress (00:02:24): 386 / 918 seconds (42.0 %)\n", - "camera_1_progress (00:02:24): 386 / 918 seconds (42.0 %)\n", - "camera_2_progress (00:02:25): 388 / 918 seconds (42.3 %)\n", - "camera_1_progress (00:02:25): 389 / 918 seconds (42.4 %)\n", - "camera_3_progress (00:02:25): 388 / 918 seconds (42.3 %)\n", - "camera_0_progress (00:02:25): 389 / 919 seconds (42.3 %)\n", - "camera_2_progress (00:02:26): 391 / 918 seconds (42.6 %)\n", - "camera_1_progress (00:02:26): 391 / 918 seconds (42.6 %)\n", - "camera_3_progress (00:02:26): 391 / 918 seconds (42.6 %)\n", - "camera_0_progress (00:02:26): 392 / 919 seconds (42.7 %)\n", - "camera_0_progress (00:02:27): 394 / 919 seconds (42.9 %)\n", - "camera_2_progress (00:02:27): 393 / 918 seconds (42.8 %)\n", - "camera_1_progress (00:02:27): 394 / 918 seconds (42.9 %)\n", - "camera_3_progress (00:02:27): 393 / 918 seconds (42.8 %)\n", - "camera_0_progress (00:02:28): 397 / 919 seconds (43.2 %)\n", - "camera_2_progress (00:02:28): 396 / 918 seconds (43.1 %)\n", - "camera_1_progress (00:02:28): 396 / 918 seconds (43.1 %)\n", - "camera_3_progress (00:02:28): 396 / 918 seconds (43.1 %)\n", - "camera_1_progress (00:02:29): 399 / 918 seconds (43.5 %)\n", - "camera_3_progress (00:02:29): 398 / 918 seconds (43.4 %)\n", - "camera_0_progress (00:02:29): 400 / 919 seconds (43.5 %)\n", - "camera_2_progress (00:02:29): 399 / 918 seconds (43.5 %)\n", - "camera_1_progress (00:02:30): 402 / 918 seconds (43.8 %)\n", - "camera_3_progress (00:02:30): 401 / 918 seconds (43.7 %)\n", - "camera_0_progress (00:02:30): 402 / 919 seconds (43.7 %)\n", - "camera_2_progress (00:02:30): 401 / 918 seconds (43.7 %)\n", - "camera_1_progress (00:02:31): 404 / 918 seconds (44.0 %)\n", - "camera_3_progress (00:02:31): 404 / 918 seconds (44.0 %)\n", - "camera_0_progress (00:02:31): 405 / 919 seconds (44.1 %)\n", - "camera_2_progress (00:02:31): 404 / 918 seconds (44.0 %)\n", - "camera_3_progress (00:02:32): 406 / 918 seconds (44.2 %)\n", - "camera_0_progress (00:02:32): 407 / 919 seconds (44.3 %)\n", - "camera_2_progress (00:02:32): 407 / 918 seconds (44.3 %)\n", - "camera_1_progress (00:02:32): 407 / 918 seconds (44.3 %)\n", - "camera_0_progress (00:02:33): 410 / 919 seconds (44.6 %)\n", - "camera_2_progress (00:02:33): 409 / 918 seconds (44.6 %)\n", - "camera_1_progress (00:02:33): 410 / 918 seconds (44.7 %)\n", - "camera_3_progress (00:02:33): 409 / 918 seconds (44.6 %)\n", - "camera_3_progress (00:02:34): 411 / 918 seconds (44.8 %)\n", - "camera_0_progress (00:02:34): 412 / 919 seconds (44.8 %)\n", - "camera_2_progress (00:02:34): 412 / 918 seconds (44.9 %)\n", - "camera_1_progress (00:02:34): 412 / 918 seconds (44.9 %)\n", - "camera_2_progress (00:02:35): 414 / 918 seconds (45.1 %)\n", - "camera_1_progress (00:02:35): 415 / 918 seconds (45.2 %)\n", - "camera_3_progress (00:02:35): 414 / 918 seconds (45.1 %)\n", - "camera_0_progress (00:02:35): 415 / 919 seconds (45.2 %)\n", - "camera_1_progress (00:02:36): 417 / 918 seconds (45.4 %)\n", - "camera_3_progress (00:02:36): 416 / 918 seconds (45.3 %)\n", - "camera_0_progress (00:02:36): 418 / 919 seconds (45.5 %)\n", - "camera_2_progress (00:02:36): 417 / 918 seconds (45.4 %)\n", - "camera_3_progress (00:02:37): 419 / 918 seconds (45.6 %)\n", - "camera_0_progress (00:02:37): 420 / 919 seconds (45.7 %)\n", - "camera_2_progress (00:02:37): 419 / 918 seconds (45.6 %)\n", - "camera_1_progress (00:02:37): 420 / 918 seconds (45.8 %)\n", - "camera_0_progress (00:02:38): 423 / 919 seconds (46.0 %)\n", - "camera_2_progress (00:02:38): 422 / 918 seconds (46.0 %)\n", - "camera_1_progress (00:02:38): 422 / 918 seconds (46.0 %)\n", - "camera_3_progress (00:02:38): 422 / 918 seconds (46.0 %)\n", - "camera_1_progress (00:02:39): 425 / 918 seconds (46.3 %)\n", - "camera_3_progress (00:02:39): 424 / 918 seconds (46.2 %)\n", - "camera_0_progress (00:02:39): 425 / 919 seconds (46.2 %)\n", - "camera_2_progress (00:02:39): 425 / 918 seconds (46.3 %)\n", - "camera_1_progress (00:02:40): 427 / 918 seconds (46.5 %)\n", - "camera_3_progress (00:02:40): 427 / 918 seconds (46.5 %)\n", - "camera_0_progress (00:02:40): 428 / 919 seconds (46.6 %)\n", - "camera_2_progress (00:02:40): 427 / 918 seconds (46.5 %)\n", - "camera_0_progress (00:02:41): 430 / 919 seconds (46.8 %)\n", - "camera_2_progress (00:02:41): 430 / 918 seconds (46.8 %)\n", - "camera_1_progress (00:02:41): 430 / 918 seconds (46.8 %)\n", - "camera_3_progress (00:02:41): 429 / 918 seconds (46.7 %)\n", - "camera_2_progress (00:02:42): 432 / 918 seconds (47.1 %)\n", - "camera_1_progress (00:02:42): 432 / 918 seconds (47.1 %)\n", - "camera_3_progress (00:02:42): 432 / 918 seconds (47.1 %)\n", - "camera_0_progress (00:02:42): 433 / 919 seconds (47.1 %)\n", - "camera_1_progress (00:02:43): 435 / 918 seconds (47.4 %)\n", - "camera_3_progress (00:02:43): 434 / 918 seconds (47.3 %)\n", - "camera_0_progress (00:02:43): 435 / 919 seconds (47.3 %)\n", - "camera_2_progress (00:02:43): 435 / 918 seconds (47.4 %)\n", - "camera_3_progress (00:02:44): 437 / 918 seconds (47.6 %)\n", - "camera_0_progress (00:02:44): 438 / 919 seconds (47.7 %)\n", - "camera_2_progress (00:02:44): 437 / 918 seconds (47.6 %)\n", - "camera_1_progress (00:02:44): 438 / 918 seconds (47.7 %)\n", - "camera_1_progress (00:02:45): 440 / 918 seconds (47.9 %)\n", - "camera_3_progress (00:02:45): 440 / 918 seconds (47.9 %)\n", - "camera_0_progress (00:02:45): 441 / 919 seconds (48.0 %)\n", - "camera_2_progress (00:02:45): 440 / 918 seconds (47.9 %)\n", - "camera_0_progress (00:02:46): 443 / 919 seconds (48.2 %)\n", - "camera_2_progress (00:02:46): 443 / 918 seconds (48.3 %)\n", - "camera_1_progress (00:02:46): 443 / 918 seconds (48.3 %)\n", - "camera_3_progress (00:02:46): 442 / 918 seconds (48.1 %)\n", - "camera_0_progress (00:02:47): 446 / 919 seconds (48.5 %)\n", - "camera_2_progress (00:02:47): 445 / 918 seconds (48.5 %)\n", - "camera_1_progress (00:02:47): 445 / 918 seconds (48.5 %)\n", - "camera_3_progress (00:02:47): 445 / 918 seconds (48.5 %)\n", - "camera_1_progress (00:02:48): 448 / 918 seconds (48.8 %)\n", - "camera_3_progress (00:02:48): 447 / 918 seconds (48.7 %)\n", - "camera_0_progress (00:02:48): 448 / 919 seconds (48.7 %)\n", - "camera_2_progress (00:02:48): 448 / 918 seconds (48.8 %)\n", - "camera_3_progress (00:02:49): 450 / 918 seconds (49.0 %)\n", - "camera_0_progress (00:02:49): 451 / 919 seconds (49.1 %)\n", - "camera_2_progress (00:02:49): 450 / 918 seconds (49.0 %)\n", - "camera_1_progress (00:02:49): 451 / 918 seconds (49.1 %)\n", - "camera_2_progress (00:02:50): 453 / 918 seconds (49.3 %)\n", - "camera_1_progress (00:02:50): 453 / 918 seconds (49.3 %)\n", - "camera_3_progress (00:02:50): 453 / 918 seconds (49.3 %)\n", - "camera_0_progress (00:02:50): 454 / 919 seconds (49.4 %)\n", - "camera_1_progress (00:02:51): 456 / 918 seconds (49.7 %)\n", - "camera_3_progress (00:02:51): 455 / 918 seconds (49.6 %)\n", - "camera_0_progress (00:02:51): 456 / 919 seconds (49.6 %)\n", - "camera_2_progress (00:02:51): 456 / 918 seconds (49.7 %)\n", - "camera_2_progress (00:02:52): 458 / 918 seconds (49.9 %)\n", - "camera_1_progress (00:02:52): 458 / 918 seconds (49.9 %)\n", - "camera_3_progress (00:02:52): 458 / 918 seconds (49.9 %)\n", - "camera_0_progress (00:02:52): 459 / 919 seconds (49.9 %)\n", - "camera_3_progress (00:02:53): 460 / 918 seconds (50.1 %)\n", - "camera_0_progress (00:02:53): 461 / 919 seconds (50.2 %)\n", - "camera_2_progress (00:02:53): 461 / 918 seconds (50.2 %)\n", - "camera_1_progress (00:02:53): 461 / 918 seconds (50.2 %)\n", - "camera_2_progress (00:02:54): 463 / 918 seconds (50.4 %)\n", - "camera_1_progress (00:02:54): 464 / 918 seconds (50.5 %)\n", - "camera_3_progress (00:02:54): 463 / 918 seconds (50.4 %)\n", - "camera_0_progress (00:02:54): 464 / 919 seconds (50.5 %)\n", - "camera_3_progress (00:02:55): 466 / 918 seconds (50.8 %)\n", - "camera_0_progress (00:02:55): 467 / 919 seconds (50.8 %)\n", - "camera_2_progress (00:02:55): 466 / 918 seconds (50.8 %)\n", - "camera_1_progress (00:02:55): 466 / 918 seconds (50.8 %)\n", - "camera_0_progress (00:02:56): 469 / 919 seconds (51.0 %)\n", - "camera_2_progress (00:02:56): 468 / 918 seconds (51.0 %)\n", - "camera_1_progress (00:02:56): 469 / 918 seconds (51.1 %)\n", - "camera_3_progress (00:02:56): 468 / 918 seconds (51.0 %)\n", - "camera_2_progress (00:02:57): 471 / 918 seconds (51.3 %)\n", - "camera_1_progress (00:02:57): 471 / 918 seconds (51.3 %)\n", - "camera_3_progress (00:02:57): 471 / 918 seconds (51.3 %)\n", - "camera_0_progress (00:02:57): 472 / 919 seconds (51.4 %)\n", - "camera_3_progress (00:02:58): 473 / 918 seconds (51.5 %)\n", - "camera_0_progress (00:02:58): 474 / 919 seconds (51.6 %)\n", - "camera_2_progress (00:02:58): 474 / 918 seconds (51.6 %)\n", - "camera_1_progress (00:02:58): 474 / 918 seconds (51.6 %)\n", - "camera_1_progress (00:02:59): 476 / 918 seconds (51.9 %)\n", - "camera_3_progress (00:02:59): 476 / 918 seconds (51.9 %)\n", - "camera_0_progress (00:02:59): 477 / 919 seconds (51.9 %)\n", - "camera_2_progress (00:02:59): 476 / 918 seconds (51.9 %)\n", - "camera_2_progress (00:03:00): 479 / 918 seconds (52.2 %)\n", - "camera_1_progress (00:03:00): 479 / 918 seconds (52.2 %)\n", - "camera_3_progress (00:03:00): 478 / 918 seconds (52.1 %)\n", - "camera_0_progress (00:03:00): 479 / 919 seconds (52.1 %)\n", - "camera_3_progress (00:03:01): 481 / 918 seconds (52.4 %)\n", - "camera_0_progress (00:03:01): 482 / 919 seconds (52.4 %)\n", - "camera_2_progress (00:03:01): 482 / 918 seconds (52.5 %)\n", - "camera_1_progress (00:03:01): 482 / 918 seconds (52.5 %)\n", - "camera_2_progress (00:03:02): 484 / 918 seconds (52.7 %)\n", - "camera_1_progress (00:03:02): 484 / 918 seconds (52.7 %)\n", - "camera_3_progress (00:03:02): 484 / 918 seconds (52.7 %)\n", - "camera_0_progress (00:03:02): 485 / 919 seconds (52.8 %)\n", - "camera_2_progress (00:03:03): 487 / 918 seconds (53.1 %)\n", - "camera_1_progress (00:03:03): 487 / 918 seconds (53.1 %)\n", - "camera_3_progress (00:03:03): 486 / 918 seconds (52.9 %)\n", - "camera_0_progress (00:03:03): 487 / 919 seconds (53.0 %)\n", - "camera_2_progress (00:03:04): 489 / 918 seconds (53.3 %)\n", - "camera_1_progress (00:03:04): 489 / 918 seconds (53.3 %)\n", - "camera_3_progress (00:03:04): 489 / 918 seconds (53.3 %)\n", - "camera_0_progress (00:03:04): 490 / 919 seconds (53.3 %)\n", - "camera_3_progress (00:03:05): 491 / 918 seconds (53.5 %)\n", - "camera_0_progress (00:03:05): 492 / 919 seconds (53.5 %)\n", - "camera_2_progress (00:03:05): 492 / 918 seconds (53.6 %)\n", - "camera_1_progress (00:03:05): 492 / 918 seconds (53.6 %)\n", - "camera_0_progress (00:03:06): 495 / 919 seconds (53.9 %)\n", - "camera_2_progress (00:03:06): 494 / 918 seconds (53.8 %)\n", - "camera_1_progress (00:03:06): 494 / 918 seconds (53.8 %)\n", - "camera_3_progress (00:03:06): 494 / 918 seconds (53.8 %)\n", - "camera_0_progress (00:03:07): 497 / 919 seconds (54.1 %)\n", - "camera_2_progress (00:03:07): 497 / 918 seconds (54.1 %)\n", - "camera_1_progress (00:03:07): 497 / 918 seconds (54.1 %)\n", - "camera_3_progress (00:03:07): 496 / 918 seconds (54.0 %)\n", - "camera_3_progress (00:03:08): 499 / 918 seconds (54.4 %)\n", - "camera_1_progress (00:03:08): 500 / 918 seconds (54.5 %)\n", - "camera_0_progress (00:03:08): 500 / 919 seconds (54.4 %)\n", - "camera_2_progress (00:03:08): 499 / 918 seconds (54.4 %)\n", - "camera_2_progress (00:03:09): 502 / 918 seconds (54.7 %)\n", - "camera_1_progress (00:03:09): 502 / 918 seconds (54.7 %)\n", - "camera_3_progress (00:03:09): 501 / 918 seconds (54.6 %)\n", - "camera_0_progress (00:03:09): 502 / 919 seconds (54.6 %)\n", - "camera_3_progress (00:03:10): 504 / 918 seconds (54.9 %)\n", - "camera_0_progress (00:03:10): 505 / 919 seconds (55.0 %)\n", - "camera_2_progress (00:03:10): 504 / 918 seconds (54.9 %)\n", - "camera_1_progress (00:03:10): 505 / 918 seconds (55.0 %)\n", - "camera_0_progress (00:03:11): 507 / 919 seconds (55.2 %)\n", - "camera_2_progress (00:03:11): 507 / 918 seconds (55.2 %)\n", - "camera_1_progress (00:03:11): 507 / 918 seconds (55.2 %)\n", - "camera_3_progress (00:03:11): 506 / 918 seconds (55.1 %)\n", - "camera_1_progress (00:03:12): 510 / 918 seconds (55.6 %)\n", - "camera_3_progress (00:03:12): 509 / 918 seconds (55.4 %)\n", - "camera_0_progress (00:03:12): 510 / 919 seconds (55.5 %)\n", - "camera_2_progress (00:03:12): 509 / 918 seconds (55.4 %)\n", - "camera_0_progress (00:03:13): 513 / 919 seconds (55.8 %)\n", - "camera_2_progress (00:03:13): 512 / 918 seconds (55.8 %)\n", - "camera_1_progress (00:03:13): 512 / 918 seconds (55.8 %)\n", - "camera_3_progress (00:03:13): 512 / 918 seconds (55.8 %)\n", - "camera_2_progress (00:03:14): 514 / 918 seconds (56.0 %)\n", - "camera_1_progress (00:03:14): 515 / 918 seconds (56.1 %)\n", - "camera_3_progress (00:03:14): 514 / 918 seconds (56.0 %)\n", - "camera_0_progress (00:03:14): 515 / 919 seconds (56.0 %)\n", - "camera_1_progress (00:03:15): 517 / 918 seconds (56.3 %)\n", - "camera_2_progress (00:03:15): 517 / 918 seconds (56.3 %)\n", - "camera_3_progress (00:03:15): 517 / 918 seconds (56.3 %)\n", - "camera_0_progress (00:03:15): 518 / 919 seconds (56.4 %)\n", - "camera_0_progress (00:03:16): 520 / 919 seconds (56.6 %)\n", - "camera_2_progress (00:03:16): 520 / 918 seconds (56.6 %)\n", - "camera_1_progress (00:03:16): 520 / 918 seconds (56.6 %)\n", - "camera_3_progress (00:03:16): 519 / 918 seconds (56.5 %)\n", - "camera_3_progress (00:03:17): 522 / 918 seconds (56.9 %)\n", - "camera_0_progress (00:03:17): 523 / 919 seconds (56.9 %)\n", - "camera_2_progress (00:03:17): 522 / 918 seconds (56.9 %)\n", - "camera_1_progress (00:03:17): 523 / 918 seconds (57.0 %)\n", - "camera_3_progress (00:03:18): 524 / 918 seconds (57.1 %)\n", - "camera_0_progress (00:03:18): 525 / 919 seconds (57.1 %)\n", - "camera_2_progress (00:03:18): 525 / 918 seconds (57.2 %)\n", - "camera_1_progress (00:03:18): 525 / 918 seconds (57.2 %)\n", - "camera_0_progress (00:03:19): 528 / 919 seconds (57.5 %)\n", - "camera_2_progress (00:03:19): 527 / 918 seconds (57.4 %)\n", - "camera_1_progress (00:03:19): 527 / 918 seconds (57.4 %)\n", - "camera_3_progress (00:03:19): 527 / 918 seconds (57.4 %)\n", - "camera_3_progress (00:03:20): 529 / 918 seconds (57.6 %)\n", - "camera_0_progress (00:03:20): 530 / 919 seconds (57.7 %)\n", - "camera_2_progress (00:03:20): 530 / 918 seconds (57.7 %)\n", - "camera_1_progress (00:03:20): 530 / 918 seconds (57.7 %)\n", - "camera_2_progress (00:03:21): 532 / 918 seconds (58.0 %)\n", - "camera_1_progress (00:03:21): 532 / 918 seconds (58.0 %)\n", - "camera_3_progress (00:03:21): 532 / 918 seconds (58.0 %)\n", - "camera_0_progress (00:03:21): 533 / 919 seconds (58.0 %)\n", - "camera_0_progress (00:03:22): 535 / 919 seconds (58.2 %)\n", - "camera_2_progress (00:03:22): 535 / 918 seconds (58.3 %)\n", - "camera_1_progress (00:03:22): 535 / 918 seconds (58.3 %)\n", - "camera_3_progress (00:03:22): 534 / 918 seconds (58.2 %)\n", - "camera_1_progress (00:03:23): 538 / 918 seconds (58.6 %)\n", - "camera_3_progress (00:03:23): 537 / 918 seconds (58.5 %)\n", - "camera_0_progress (00:03:23): 538 / 919 seconds (58.5 %)\n", - "camera_2_progress (00:03:23): 537 / 918 seconds (58.5 %)\n", - "camera_1_progress (00:03:24): 540 / 918 seconds (58.8 %)\n", - "camera_3_progress (00:03:24): 540 / 918 seconds (58.8 %)\n", - "camera_0_progress (00:03:24): 541 / 919 seconds (58.9 %)\n", - "camera_2_progress (00:03:24): 540 / 918 seconds (58.8 %)\n", - "camera_0_progress (00:03:25): 543 / 919 seconds (59.1 %)\n", - "camera_2_progress (00:03:25): 542 / 918 seconds (59.0 %)\n", - "camera_1_progress (00:03:25): 543 / 918 seconds (59.2 %)\n", - "camera_3_progress (00:03:25): 542 / 918 seconds (59.0 %)\n", - "camera_0_progress (00:03:26): 545 / 919 seconds (59.3 %)\n", - "camera_2_progress (00:03:26): 545 / 918 seconds (59.4 %)\n", - "camera_1_progress (00:03:26): 545 / 918 seconds (59.4 %)\n", - "camera_3_progress (00:03:26): 544 / 918 seconds (59.3 %)\n", - "camera_1_progress (00:03:27): 548 / 918 seconds (59.7 %)\n", - "camera_3_progress (00:03:27): 547 / 918 seconds (59.6 %)\n", - "camera_0_progress (00:03:27): 548 / 919 seconds (59.6 %)\n", - "camera_2_progress (00:03:27): 547 / 918 seconds (59.6 %)\n", - "camera_2_progress (00:03:28): 550 / 918 seconds (59.9 %)\n", - "camera_1_progress (00:03:28): 550 / 918 seconds (59.9 %)\n", - "camera_3_progress (00:03:28): 549 / 918 seconds (59.8 %)\n", - "camera_0_progress (00:03:28): 551 / 919 seconds (60.0 %)\n", - "camera_3_progress (00:03:29): 552 / 918 seconds (60.1 %)\n", - "camera_0_progress (00:03:29): 553 / 919 seconds (60.2 %)\n", - "camera_2_progress (00:03:29): 552 / 918 seconds (60.1 %)\n", - "camera_1_progress (00:03:29): 553 / 918 seconds (60.2 %)\n", - "camera_1_progress (00:03:30): 555 / 918 seconds (60.5 %)\n", - "camera_3_progress (00:03:30): 554 / 918 seconds (60.3 %)\n", - "camera_0_progress (00:03:30): 555 / 919 seconds (60.4 %)\n", - "camera_2_progress (00:03:30): 555 / 918 seconds (60.5 %)\n", - "camera_2_progress (00:03:31): 557 / 918 seconds (60.7 %)\n", - "camera_1_progress (00:03:31): 557 / 918 seconds (60.7 %)\n", - "camera_3_progress (00:03:31): 557 / 918 seconds (60.7 %)\n", - "camera_0_progress (00:03:31): 558 / 919 seconds (60.7 %)\n", - "camera_0_progress (00:03:32): 560 / 919 seconds (60.9 %)\n", - "camera_2_progress (00:03:32): 560 / 918 seconds (61.0 %)\n", - "camera_1_progress (00:03:32): 560 / 918 seconds (61.0 %)\n", - "camera_3_progress (00:03:32): 559 / 918 seconds (60.9 %)\n", - "camera_2_progress (00:03:33): 562 / 918 seconds (61.2 %)\n", - "camera_1_progress (00:03:33): 562 / 918 seconds (61.2 %)\n", - "camera_3_progress (00:03:33): 562 / 918 seconds (61.2 %)\n", - "camera_0_progress (00:03:33): 563 / 919 seconds (61.3 %)\n", - "camera_1_progress (00:03:34): 565 / 918 seconds (61.5 %)\n", - "camera_3_progress (00:03:34): 564 / 918 seconds (61.4 %)\n", - "camera_0_progress (00:03:34): 565 / 919 seconds (61.5 %)\n", - "camera_2_progress (00:03:34): 565 / 918 seconds (61.5 %)\n", - "camera_0_progress (00:03:35): 568 / 919 seconds (61.8 %)\n", - "camera_2_progress (00:03:35): 567 / 918 seconds (61.8 %)\n", - "camera_1_progress (00:03:35): 567 / 918 seconds (61.8 %)\n", - "camera_3_progress (00:03:35): 567 / 918 seconds (61.8 %)\n", - "camera_1_progress (00:03:36): 570 / 918 seconds (62.1 %)\n", - "camera_3_progress (00:03:36): 569 / 918 seconds (62.0 %)\n", - "camera_0_progress (00:03:36): 570 / 919 seconds (62.0 %)\n", - "camera_2_progress (00:03:36): 569 / 918 seconds (62.0 %)\n", - "camera_0_progress (00:03:37): 572 / 919 seconds (62.2 %)\n", - "camera_2_progress (00:03:37): 572 / 918 seconds (62.3 %)\n", - "camera_1_progress (00:03:37): 572 / 918 seconds (62.3 %)\n", - "camera_3_progress (00:03:37): 571 / 918 seconds (62.2 %)\n", - "camera_2_progress (00:03:38): 574 / 918 seconds (62.5 %)\n", - "camera_1_progress (00:03:38): 574 / 918 seconds (62.5 %)\n", - "camera_3_progress (00:03:38): 574 / 918 seconds (62.5 %)\n", - "camera_0_progress (00:03:38): 575 / 919 seconds (62.6 %)\n", - "camera_0_progress (00:03:39): 578 / 919 seconds (62.9 %)\n", - "camera_2_progress (00:03:39): 577 / 918 seconds (62.9 %)\n", - "camera_1_progress (00:03:39): 577 / 918 seconds (62.9 %)\n", - "camera_3_progress (00:03:39): 577 / 918 seconds (62.9 %)\n", - "camera_1_progress (00:03:40): 579 / 918 seconds (63.1 %)\n", - "camera_3_progress (00:03:40): 579 / 918 seconds (63.1 %)\n", - "camera_0_progress (00:03:40): 580 / 919 seconds (63.1 %)\n", - "camera_2_progress (00:03:40): 579 / 918 seconds (63.1 %)\n", - "camera_3_progress (00:03:41): 581 / 918 seconds (63.3 %)\n", - "camera_0_progress (00:03:41): 582 / 919 seconds (63.3 %)\n", - "camera_2_progress (00:03:41): 582 / 918 seconds (63.4 %)\n", - "camera_1_progress (00:03:41): 582 / 918 seconds (63.4 %)\n", - "camera_2_progress (00:03:42): 584 / 918 seconds (63.6 %)\n", - "camera_1_progress (00:03:42): 584 / 918 seconds (63.6 %)\n", - "camera_3_progress (00:03:42): 584 / 918 seconds (63.6 %)\n", - "camera_0_progress (00:03:42): 585 / 919 seconds (63.7 %)\n", - "camera_0_progress (00:03:43): 587 / 919 seconds (63.9 %)\n", - "camera_2_progress (00:03:43): 586 / 918 seconds (63.8 %)\n", - "camera_1_progress (00:03:43): 587 / 918 seconds (63.9 %)\n", - "camera_3_progress (00:03:43): 586 / 918 seconds (63.8 %)\n", - "camera_3_progress (00:03:44): 589 / 918 seconds (64.2 %)\n", - "camera_0_progress (00:03:44): 590 / 919 seconds (64.2 %)\n", - "camera_2_progress (00:03:44): 589 / 918 seconds (64.2 %)\n", - "camera_1_progress (00:03:44): 590 / 918 seconds (64.3 %)\n", - "camera_1_progress (00:03:45): 592 / 918 seconds (64.5 %)\n", - "camera_3_progress (00:03:45): 591 / 918 seconds (64.4 %)\n", - "camera_0_progress (00:03:45): 592 / 919 seconds (64.4 %)\n", - "camera_2_progress (00:03:45): 592 / 918 seconds (64.5 %)\n", - "camera_1_progress (00:03:46): 594 / 918 seconds (64.7 %)\n", - "camera_3_progress (00:03:46): 594 / 918 seconds (64.7 %)\n", - "camera_0_progress (00:03:46): 595 / 919 seconds (64.7 %)\n", - "camera_2_progress (00:03:46): 594 / 918 seconds (64.7 %)\n", - "camera_0_progress (00:03:47): 597 / 919 seconds (65.0 %)\n", - "camera_2_progress (00:03:47): 596 / 918 seconds (64.9 %)\n", - "camera_1_progress (00:03:47): 597 / 918 seconds (65.0 %)\n", - "camera_3_progress (00:03:47): 596 / 918 seconds (64.9 %)\n", - "camera_1_progress (00:03:48): 599 / 918 seconds (65.3 %)\n", - "camera_3_progress (00:03:48): 599 / 918 seconds (65.3 %)\n", - "camera_0_progress (00:03:48): 600 / 919 seconds (65.3 %)\n", - "camera_2_progress (00:03:48): 599 / 918 seconds (65.3 %)\n", - "camera_1_progress (00:03:49): 602 / 918 seconds (65.6 %)\n", - "camera_2_progress (00:03:49): 601 / 918 seconds (65.5 %)\n", - "camera_3_progress (00:03:49): 601 / 918 seconds (65.5 %)\n", - "camera_0_progress (00:03:49): 602 / 919 seconds (65.5 %)\n", - "camera_0_progress (00:03:50): 605 / 919 seconds (65.8 %)\n", - "camera_2_progress (00:03:50): 604 / 918 seconds (65.8 %)\n", - "camera_1_progress (00:03:50): 604 / 918 seconds (65.8 %)\n", - "camera_3_progress (00:03:50): 604 / 918 seconds (65.8 %)\n", - "camera_0_progress (00:03:51): 607 / 919 seconds (66.1 %)\n", - "camera_2_progress (00:03:51): 606 / 918 seconds (66.0 %)\n", - "camera_1_progress (00:03:51): 607 / 918 seconds (66.1 %)\n", - "camera_3_progress (00:03:51): 607 / 918 seconds (66.1 %)\n", - "camera_1_progress (00:03:52): 609 / 918 seconds (66.3 %)\n", - "camera_3_progress (00:03:52): 609 / 918 seconds (66.3 %)\n", - "camera_0_progress (00:03:52): 610 / 919 seconds (66.4 %)\n", - "camera_2_progress (00:03:52): 609 / 918 seconds (66.3 %)\n", - "camera_1_progress (00:03:53): 612 / 918 seconds (66.7 %)\n", - "camera_3_progress (00:03:53): 611 / 918 seconds (66.6 %)\n", - "camera_0_progress (00:03:53): 612 / 919 seconds (66.6 %)\n", - "camera_2_progress (00:03:53): 611 / 918 seconds (66.6 %)\n", - "camera_1_progress (00:03:54): 614 / 918 seconds (66.9 %)\n", - "camera_3_progress (00:03:54): 614 / 918 seconds (66.9 %)\n", - "camera_0_progress (00:03:54): 615 / 919 seconds (66.9 %)\n", - "camera_2_progress (00:03:54): 614 / 918 seconds (66.9 %)\n", - "camera_1_progress (00:03:55): 617 / 918 seconds (67.2 %)\n", - "camera_3_progress (00:03:55): 616 / 918 seconds (67.1 %)\n", - "camera_0_progress (00:03:55): 617 / 919 seconds (67.1 %)\n", - "camera_2_progress (00:03:55): 617 / 918 seconds (67.2 %)\n", - "camera_2_progress (00:03:56): 619 / 918 seconds (67.4 %)\n", - "camera_1_progress (00:03:56): 619 / 918 seconds (67.4 %)\n", - "camera_3_progress (00:03:56): 619 / 918 seconds (67.4 %)\n", - "camera_0_progress (00:03:56): 620 / 919 seconds (67.5 %)\n", - "camera_0_progress (00:03:57): 622 / 919 seconds (67.7 %)\n", - "camera_2_progress (00:03:57): 621 / 918 seconds (67.6 %)\n", - "camera_1_progress (00:03:57): 622 / 918 seconds (67.8 %)\n", - "camera_3_progress (00:03:57): 621 / 918 seconds (67.6 %)\n", - "camera_0_progress (00:03:58): 625 / 919 seconds (68.0 %)\n", - "camera_2_progress (00:03:58): 624 / 918 seconds (68.0 %)\n", - "camera_1_progress (00:03:58): 624 / 918 seconds (68.0 %)\n", - "camera_3_progress (00:03:58): 624 / 918 seconds (68.0 %)\n", - "camera_1_progress (00:03:59): 627 / 918 seconds (68.3 %)\n", - "camera_3_progress (00:03:59): 626 / 918 seconds (68.2 %)\n", - "camera_0_progress (00:03:59): 627 / 919 seconds (68.2 %)\n", - "camera_2_progress (00:03:59): 627 / 918 seconds (68.3 %)\n", - "camera_1_progress (00:04:00): 629 / 918 seconds (68.5 %)\n", - "camera_3_progress (00:04:00): 629 / 918 seconds (68.5 %)\n", - "camera_0_progress (00:04:00): 630 / 919 seconds (68.6 %)\n", - "camera_2_progress (00:04:00): 629 / 918 seconds (68.5 %)\n", - "camera_1_progress (00:04:01): 632 / 918 seconds (68.8 %)\n", - "camera_3_progress (00:04:01): 631 / 918 seconds (68.7 %)\n", - "camera_0_progress (00:04:01): 632 / 919 seconds (68.8 %)\n", - "camera_2_progress (00:04:01): 631 / 918 seconds (68.7 %)\n", - "camera_3_progress (00:04:02): 634 / 918 seconds (69.1 %)\n", - "camera_0_progress (00:04:02): 635 / 919 seconds (69.1 %)\n", - "camera_2_progress (00:04:02): 634 / 918 seconds (69.1 %)\n", - "camera_1_progress (00:04:02): 634 / 918 seconds (69.1 %)\n", - "camera_2_progress (00:04:03): 636 / 918 seconds (69.3 %)\n", - "camera_1_progress (00:04:03): 637 / 918 seconds (69.4 %)\n", - "camera_3_progress (00:04:03): 636 / 918 seconds (69.3 %)\n", - "camera_0_progress (00:04:03): 637 / 919 seconds (69.3 %)\n", - "camera_1_progress (00:04:04): 639 / 918 seconds (69.6 %)\n", - "camera_3_progress (00:04:04): 639 / 918 seconds (69.6 %)\n", - "camera_0_progress (00:04:04): 640 / 919 seconds (69.6 %)\n", - "camera_2_progress (00:04:04): 639 / 918 seconds (69.6 %)\n", - "camera_2_progress (00:04:05): 641 / 918 seconds (69.8 %)\n", - "camera_1_progress (00:04:05): 642 / 918 seconds (69.9 %)\n", - "camera_3_progress (00:04:05): 641 / 918 seconds (69.8 %)\n", - "camera_0_progress (00:04:05): 642 / 919 seconds (69.9 %)\n", - "camera_1_progress (00:04:06): 644 / 918 seconds (70.2 %)\n", - "camera_3_progress (00:04:06): 644 / 918 seconds (70.2 %)\n", - "camera_0_progress (00:04:06): 645 / 919 seconds (70.2 %)\n", - "camera_2_progress (00:04:06): 644 / 918 seconds (70.2 %)\n", - "camera_1_progress (00:04:07): 647 / 918 seconds (70.5 %)\n", - "camera_3_progress (00:04:07): 646 / 918 seconds (70.4 %)\n", - "camera_0_progress (00:04:07): 647 / 919 seconds (70.4 %)\n", - "camera_2_progress (00:04:07): 647 / 918 seconds (70.5 %)\n", - "camera_0_progress (00:04:08): 650 / 919 seconds (70.7 %)\n", - "camera_2_progress (00:04:08): 649 / 918 seconds (70.7 %)\n", - "camera_1_progress (00:04:08): 649 / 918 seconds (70.7 %)\n", - "camera_3_progress (00:04:08): 649 / 918 seconds (70.7 %)\n", - "camera_3_progress (00:04:09): 651 / 918 seconds (70.9 %)\n", - "camera_0_progress (00:04:09): 652 / 919 seconds (70.9 %)\n", - "camera_2_progress (00:04:09): 652 / 918 seconds (71.0 %)\n", - "camera_1_progress (00:04:09): 652 / 918 seconds (71.0 %)\n", - "camera_2_progress (00:04:10): 654 / 918 seconds (71.2 %)\n", - "camera_1_progress (00:04:10): 654 / 918 seconds (71.2 %)\n", - "camera_3_progress (00:04:10): 654 / 918 seconds (71.2 %)\n", - "camera_0_progress (00:04:10): 655 / 919 seconds (71.3 %)\n", - "camera_3_progress (00:04:11): 656 / 918 seconds (71.5 %)\n", - "camera_0_progress (00:04:11): 657 / 919 seconds (71.5 %)\n", - "camera_2_progress (00:04:11): 656 / 918 seconds (71.5 %)\n", - "camera_1_progress (00:04:11): 657 / 918 seconds (71.6 %)\n", - "camera_2_progress (00:04:12): 659 / 918 seconds (71.8 %)\n", - "camera_1_progress (00:04:12): 659 / 918 seconds (71.8 %)\n", - "camera_3_progress (00:04:12): 659 / 918 seconds (71.8 %)\n", - "camera_0_progress (00:04:12): 660 / 919 seconds (71.8 %)\n", - "camera_3_progress (00:04:13): 661 / 918 seconds (72.0 %)\n", - "camera_0_progress (00:04:13): 662 / 919 seconds (72.0 %)\n", - "camera_2_progress (00:04:13): 662 / 918 seconds (72.1 %)\n", - "camera_1_progress (00:04:13): 662 / 918 seconds (72.1 %)\n", - "camera_3_progress (00:04:14): 664 / 918 seconds (72.3 %)\n", - "camera_0_progress (00:04:14): 665 / 919 seconds (72.4 %)\n", - "camera_2_progress (00:04:14): 664 / 918 seconds (72.3 %)\n", - "camera_1_progress (00:04:14): 664 / 918 seconds (72.3 %)\n", - "camera_3_progress (00:04:15): 666 / 918 seconds (72.5 %)\n", - "camera_0_progress (00:04:15): 667 / 919 seconds (72.6 %)\n", - "camera_2_progress (00:04:15): 666 / 918 seconds (72.5 %)\n", - "camera_1_progress (00:04:15): 667 / 918 seconds (72.7 %)\n", - "camera_3_progress (00:04:16): 669 / 918 seconds (72.9 %)\n", - "camera_0_progress (00:04:16): 670 / 919 seconds (72.9 %)\n", - "camera_2_progress (00:04:16): 669 / 918 seconds (72.9 %)\n", - "camera_1_progress (00:04:16): 669 / 918 seconds (72.9 %)\n", - "camera_0_progress (00:04:17): 672 / 919 seconds (73.1 %)\n", - "camera_2_progress (00:04:17): 672 / 918 seconds (73.2 %)\n", - "camera_1_progress (00:04:17): 672 / 918 seconds (73.2 %)\n", - "camera_3_progress (00:04:17): 671 / 918 seconds (73.1 %)\n", - "camera_1_progress (00:04:18): 674 / 918 seconds (73.4 %)\n", - "camera_3_progress (00:04:18): 674 / 918 seconds (73.4 %)\n", - "camera_0_progress (00:04:18): 675 / 919 seconds (73.4 %)\n", - "camera_2_progress (00:04:18): 674 / 918 seconds (73.4 %)\n", - "camera_0_progress (00:04:19): 677 / 919 seconds (73.7 %)\n", - "camera_2_progress (00:04:19): 677 / 918 seconds (73.7 %)\n", - "camera_1_progress (00:04:19): 677 / 918 seconds (73.7 %)\n", - "camera_3_progress (00:04:19): 676 / 918 seconds (73.6 %)\n", - "camera_3_progress (00:04:20): 679 / 918 seconds (74.0 %)\n", - "camera_0_progress (00:04:20): 680 / 919 seconds (74.0 %)\n", - "camera_2_progress (00:04:20): 679 / 918 seconds (74.0 %)\n", - "camera_1_progress (00:04:20): 679 / 918 seconds (74.0 %)\n", - "camera_1_progress (00:04:21): 682 / 918 seconds (74.3 %)\n", - "camera_3_progress (00:04:21): 681 / 918 seconds (74.2 %)\n", - "camera_0_progress (00:04:21): 682 / 919 seconds (74.2 %)\n", - "camera_2_progress (00:04:21): 681 / 918 seconds (74.2 %)\n", - "camera_0_progress (00:04:22): 684 / 919 seconds (74.4 %)\n", - "camera_2_progress (00:04:22): 684 / 918 seconds (74.5 %)\n", - "camera_1_progress (00:04:22): 684 / 918 seconds (74.5 %)\n", - "camera_3_progress (00:04:22): 684 / 918 seconds (74.5 %)\n", - "camera_0_progress (00:04:23): 687 / 919 seconds (74.8 %)\n", - "camera_2_progress (00:04:23): 686 / 918 seconds (74.7 %)\n", - "camera_1_progress (00:04:23): 686 / 918 seconds (74.7 %)\n", - "camera_3_progress (00:04:23): 686 / 918 seconds (74.7 %)\n", - "camera_3_progress (00:04:24): 688 / 918 seconds (74.9 %)\n", - "camera_0_progress (00:04:24): 689 / 919 seconds (75.0 %)\n", - "camera_2_progress (00:04:24): 689 / 918 seconds (75.1 %)\n", - "camera_1_progress (00:04:24): 689 / 918 seconds (75.1 %)\n", - "camera_3_progress (00:04:25): 691 / 918 seconds (75.3 %)\n", - "camera_0_progress (00:04:25): 692 / 919 seconds (75.3 %)\n", - "camera_2_progress (00:04:25): 691 / 918 seconds (75.3 %)\n", - "camera_1_progress (00:04:25): 692 / 918 seconds (75.4 %)\n", - "camera_0_progress (00:04:26): 695 / 919 seconds (75.6 %)\n", - "camera_2_progress (00:04:26): 694 / 918 seconds (75.6 %)\n", - "camera_1_progress (00:04:26): 694 / 918 seconds (75.6 %)\n", - "camera_3_progress (00:04:26): 694 / 918 seconds (75.6 %)\n", - "camera_0_progress (00:04:27): 697 / 919 seconds (75.8 %)\n", - "camera_2_progress (00:04:27): 696 / 918 seconds (75.8 %)\n", - "camera_1_progress (00:04:27): 697 / 918 seconds (75.9 %)\n", - "camera_3_progress (00:04:27): 696 / 918 seconds (75.8 %)\n", - "camera_0_progress (00:04:28): 699 / 919 seconds (76.1 %)\n", - "camera_2_progress (00:04:28): 699 / 918 seconds (76.1 %)\n", - "camera_1_progress (00:04:28): 699 / 918 seconds (76.1 %)\n", - "camera_3_progress (00:04:28): 698 / 918 seconds (76.0 %)\n", - "camera_3_progress (00:04:29): 701 / 918 seconds (76.4 %)\n", - "camera_0_progress (00:04:29): 702 / 919 seconds (76.4 %)\n", - "camera_2_progress (00:04:29): 701 / 918 seconds (76.4 %)\n", - "camera_1_progress (00:04:29): 702 / 918 seconds (76.5 %)\n", - "camera_2_progress (00:04:30): 703 / 918 seconds (76.6 %)\n", - "camera_1_progress (00:04:30): 704 / 918 seconds (76.7 %)\n", - "camera_3_progress (00:04:30): 703 / 918 seconds (76.6 %)\n", - "camera_0_progress (00:04:30): 704 / 919 seconds (76.6 %)\n", - "camera_3_progress (00:04:31): 705 / 918 seconds (76.8 %)\n", - "camera_0_progress (00:04:31): 707 / 919 seconds (76.9 %)\n", - "camera_2_progress (00:04:31): 706 / 918 seconds (76.9 %)\n", - "camera_1_progress (00:04:31): 706 / 918 seconds (76.9 %)\n", - "camera_1_progress (00:04:32): 708 / 918 seconds (77.1 %)\n", - "camera_3_progress (00:04:32): 708 / 918 seconds (77.1 %)\n", - "camera_0_progress (00:04:32): 709 / 919 seconds (77.1 %)\n", - "camera_2_progress (00:04:32): 708 / 918 seconds (77.1 %)\n", - "camera_1_progress (00:04:33): 711 / 918 seconds (77.5 %)\n", - "camera_3_progress (00:04:33): 710 / 918 seconds (77.3 %)\n", - "camera_0_progress (00:04:33): 711 / 919 seconds (77.4 %)\n", - "camera_2_progress (00:04:33): 711 / 918 seconds (77.5 %)\n", - "camera_3_progress (00:04:34): 713 / 918 seconds (77.7 %)\n", - "camera_0_progress (00:04:34): 714 / 919 seconds (77.7 %)\n", - "camera_2_progress (00:04:34): 713 / 918 seconds (77.7 %)\n", - "camera_1_progress (00:04:34): 713 / 918 seconds (77.7 %)\n", - "camera_3_progress (00:04:35): 715 / 918 seconds (77.9 %)\n", - "camera_0_progress (00:04:35): 716 / 919 seconds (77.9 %)\n", - "camera_2_progress (00:04:35): 716 / 918 seconds (78.0 %)\n", - "camera_1_progress (00:04:35): 716 / 918 seconds (78.0 %)\n", - "camera_1_progress (00:04:36): 718 / 918 seconds (78.2 %)\n", - "camera_3_progress (00:04:36): 718 / 918 seconds (78.2 %)\n", - "camera_0_progress (00:04:36): 719 / 919 seconds (78.2 %)\n", - "camera_2_progress (00:04:36): 718 / 918 seconds (78.2 %)\n", - "camera_2_progress (00:04:37): 720 / 918 seconds (78.4 %)\n", - "camera_1_progress (00:04:37): 721 / 918 seconds (78.5 %)\n", - "camera_3_progress (00:04:37): 720 / 918 seconds (78.4 %)\n", - "camera_0_progress (00:04:37): 721 / 919 seconds (78.5 %)\n", - "camera_0_progress (00:04:38): 723 / 919 seconds (78.7 %)\n", - "camera_2_progress (00:04:38): 723 / 918 seconds (78.8 %)\n", - "camera_1_progress (00:04:38): 723 / 918 seconds (78.8 %)\n", - "camera_3_progress (00:04:38): 722 / 918 seconds (78.6 %)\n", - "camera_3_progress (00:04:39): 725 / 918 seconds (79.0 %)\n", - "camera_0_progress (00:04:39): 726 / 919 seconds (79.0 %)\n", - "camera_2_progress (00:04:39): 725 / 918 seconds (79.0 %)\n", - "camera_1_progress (00:04:39): 726 / 918 seconds (79.1 %)\n", - "camera_0_progress (00:04:40): 729 / 919 seconds (79.3 %)\n", - "camera_2_progress (00:04:40): 728 / 918 seconds (79.3 %)\n", - "camera_1_progress (00:04:40): 728 / 918 seconds (79.3 %)\n", - "camera_3_progress (00:04:40): 728 / 918 seconds (79.3 %)\n", - "camera_0_progress (00:04:41): 731 / 919 seconds (79.5 %)\n", - "camera_2_progress (00:04:41): 731 / 918 seconds (79.6 %)\n", - "camera_1_progress (00:04:41): 731 / 918 seconds (79.6 %)\n", - "camera_3_progress (00:04:41): 730 / 918 seconds (79.5 %)\n", - "camera_3_progress (00:04:42): 733 / 918 seconds (79.8 %)\n", - "camera_0_progress (00:04:42): 734 / 919 seconds (79.9 %)\n", - "camera_2_progress (00:04:42): 733 / 918 seconds (79.8 %)\n", - "camera_1_progress (00:04:42): 733 / 918 seconds (79.8 %)\n", - "camera_0_progress (00:04:43): 736 / 919 seconds (80.1 %)\n", - "camera_2_progress (00:04:43): 735 / 918 seconds (80.1 %)\n", - "camera_1_progress (00:04:43): 736 / 918 seconds (80.2 %)\n", - "camera_3_progress (00:04:43): 735 / 918 seconds (80.1 %)\n", - "camera_3_progress (00:04:44): 738 / 918 seconds (80.4 %)\n", - "camera_0_progress (00:04:44): 739 / 919 seconds (80.4 %)\n", - "camera_2_progress (00:04:44): 738 / 918 seconds (80.4 %)\n", - "camera_1_progress (00:04:44): 738 / 918 seconds (80.4 %)\n", - "camera_0_progress (00:04:45): 741 / 919 seconds (80.6 %)\n", - "camera_2_progress (00:04:45): 740 / 918 seconds (80.6 %)\n", - "camera_1_progress (00:04:45): 741 / 918 seconds (80.7 %)\n", - "camera_3_progress (00:04:45): 740 / 918 seconds (80.6 %)\n", - "camera_0_progress (00:04:46): 744 / 919 seconds (81.0 %)\n", - "camera_2_progress (00:04:46): 743 / 918 seconds (80.9 %)\n", - "camera_1_progress (00:04:46): 743 / 918 seconds (80.9 %)\n", - "camera_3_progress (00:04:46): 743 / 918 seconds (80.9 %)\n", - "camera_1_progress (00:04:47): 746 / 918 seconds (81.3 %)\n", - "camera_3_progress (00:04:47): 745 / 918 seconds (81.2 %)\n", - "camera_0_progress (00:04:47): 746 / 919 seconds (81.2 %)\n", - "camera_2_progress (00:04:47): 746 / 918 seconds (81.3 %)\n", - "camera_3_progress (00:04:48): 748 / 918 seconds (81.5 %)\n", - "camera_0_progress (00:04:48): 749 / 919 seconds (81.5 %)\n", - "camera_2_progress (00:04:48): 748 / 918 seconds (81.5 %)\n", - "camera_1_progress (00:04:48): 748 / 918 seconds (81.5 %)\n", - "camera_0_progress (00:04:49): 751 / 919 seconds (81.7 %)\n", - "camera_2_progress (00:04:49): 750 / 918 seconds (81.7 %)\n", - "camera_1_progress (00:04:49): 751 / 918 seconds (81.8 %)\n", - "camera_3_progress (00:04:49): 750 / 918 seconds (81.7 %)\n", - "camera_2_progress (00:04:50): 753 / 918 seconds (82.0 %)\n", - "camera_1_progress (00:04:50): 753 / 918 seconds (82.0 %)\n", - "camera_3_progress (00:04:50): 753 / 918 seconds (82.0 %)\n", - "camera_0_progress (00:04:50): 754 / 919 seconds (82.0 %)\n", - "camera_1_progress (00:04:51): 756 / 918 seconds (82.4 %)\n", - "camera_3_progress (00:04:51): 755 / 918 seconds (82.2 %)\n", - "camera_0_progress (00:04:51): 756 / 919 seconds (82.3 %)\n", - "camera_2_progress (00:04:51): 756 / 918 seconds (82.4 %)\n", - "camera_2_progress (00:04:52): 758 / 918 seconds (82.6 %)\n", - "camera_1_progress (00:04:52): 758 / 918 seconds (82.6 %)\n", - "camera_3_progress (00:04:52): 758 / 918 seconds (82.6 %)\n", - "camera_0_progress (00:04:52): 759 / 919 seconds (82.6 %)\n", - "camera_1_progress (00:04:53): 761 / 918 seconds (82.9 %)\n", - "camera_3_progress (00:04:53): 760 / 918 seconds (82.8 %)\n", - "camera_0_progress (00:04:53): 761 / 919 seconds (82.8 %)\n", - "camera_2_progress (00:04:53): 761 / 918 seconds (82.9 %)\n", - "camera_0_progress (00:04:54): 764 / 919 seconds (83.1 %)\n", - "camera_2_progress (00:04:54): 763 / 918 seconds (83.1 %)\n", - "camera_1_progress (00:04:54): 763 / 918 seconds (83.1 %)\n", - "camera_3_progress (00:04:54): 763 / 918 seconds (83.1 %)\n", - "camera_3_progress (00:04:55): 765 / 918 seconds (83.3 %)\n", - "camera_0_progress (00:04:55): 766 / 919 seconds (83.4 %)\n", - "camera_2_progress (00:04:55): 766 / 918 seconds (83.4 %)\n", - "camera_1_progress (00:04:55): 766 / 918 seconds (83.4 %)\n", - "camera_1_progress (00:04:56): 768 / 918 seconds (83.7 %)\n", - "camera_3_progress (00:04:56): 768 / 918 seconds (83.7 %)\n", - "camera_0_progress (00:04:56): 769 / 919 seconds (83.7 %)\n", - "camera_2_progress (00:04:56): 768 / 918 seconds (83.7 %)\n", - "camera_2_progress (00:04:57): 771 / 918 seconds (84.0 %)\n", - "camera_1_progress (00:04:57): 771 / 918 seconds (84.0 %)\n", - "camera_3_progress (00:04:57): 770 / 918 seconds (83.9 %)\n", - "camera_0_progress (00:04:57): 771 / 919 seconds (83.9 %)\n", - "camera_2_progress (00:04:58): 773 / 918 seconds (84.2 %)\n", - "camera_1_progress (00:04:58): 774 / 918 seconds (84.3 %)\n", - "camera_3_progress (00:04:58): 773 / 918 seconds (84.2 %)\n", - "camera_0_progress (00:04:58): 774 / 919 seconds (84.2 %)\n", - "camera_2_progress (00:04:59): 776 / 918 seconds (84.5 %)\n", - "camera_1_progress (00:04:59): 776 / 918 seconds (84.5 %)\n", - "camera_3_progress (00:04:59): 775 / 918 seconds (84.4 %)\n", - "camera_0_progress (00:04:59): 776 / 919 seconds (84.4 %)\n", - "camera_3_progress (00:05:00): 778 / 918 seconds (84.7 %)\n", - "camera_0_progress (00:05:00): 779 / 919 seconds (84.8 %)\n", - "camera_2_progress (00:05:00): 779 / 918 seconds (84.9 %)\n", - "camera_1_progress (00:05:00): 779 / 918 seconds (84.9 %)\n", - "camera_0_progress (00:05:01): 782 / 919 seconds (85.1 %)\n", - "camera_2_progress (00:05:01): 781 / 918 seconds (85.1 %)\n", - "camera_1_progress (00:05:01): 781 / 918 seconds (85.1 %)\n", - "camera_3_progress (00:05:01): 781 / 918 seconds (85.1 %)\n", - "camera_2_progress (00:05:02): 784 / 918 seconds (85.4 %)\n", - "camera_1_progress (00:05:02): 784 / 918 seconds (85.4 %)\n", - "camera_3_progress (00:05:02): 783 / 918 seconds (85.3 %)\n", - "camera_0_progress (00:05:02): 784 / 919 seconds (85.3 %)\n", - "camera_2_progress (00:05:03): 786 / 918 seconds (85.6 %)\n", - "camera_1_progress (00:05:03): 786 / 918 seconds (85.6 %)\n", - "camera_3_progress (00:05:03): 786 / 918 seconds (85.6 %)\n", - "camera_0_progress (00:05:03): 787 / 919 seconds (85.6 %)\n", - "camera_2_progress (00:05:04): 788 / 918 seconds (85.8 %)\n", - "camera_1_progress (00:05:04): 789 / 918 seconds (85.9 %)\n", - "camera_3_progress (00:05:04): 788 / 918 seconds (85.8 %)\n", - "camera_0_progress (00:05:04): 789 / 919 seconds (85.9 %)\n", - "camera_0_progress (00:05:05): 792 / 919 seconds (86.2 %)\n", - "camera_2_progress (00:05:05): 791 / 918 seconds (86.2 %)\n", - "camera_1_progress (00:05:05): 791 / 918 seconds (86.2 %)\n", - "camera_3_progress (00:05:05): 791 / 918 seconds (86.2 %)\n", - "camera_3_progress (00:05:06): 793 / 918 seconds (86.4 %)\n", - "camera_0_progress (00:05:06): 794 / 919 seconds (86.4 %)\n", - "camera_2_progress (00:05:06): 793 / 918 seconds (86.4 %)\n", - "camera_1_progress (00:05:06): 794 / 918 seconds (86.5 %)\n", - "camera_2_progress (00:05:07): 796 / 918 seconds (86.7 %)\n", - "camera_0_progress (00:05:07): 797 / 919 seconds (86.7 %)\n", - "camera_1_progress (00:05:07): 796 / 918 seconds (86.7 %)\n", - "camera_3_progress (00:05:07): 796 / 918 seconds (86.7 %)\n", - "camera_3_progress (00:05:08): 798 / 918 seconds (86.9 %)\n", - "camera_0_progress (00:05:08): 799 / 919 seconds (86.9 %)\n", - "camera_2_progress (00:05:08): 799 / 918 seconds (87.0 %)\n", - "camera_1_progress (00:05:08): 799 / 918 seconds (87.0 %)\n", - "camera_3_progress (00:05:09): 801 / 918 seconds (87.3 %)\n", - "camera_0_progress (00:05:09): 802 / 919 seconds (87.3 %)\n", - "camera_2_progress (00:05:09): 801 / 918 seconds (87.3 %)\n", - "camera_1_progress (00:05:09): 802 / 918 seconds (87.4 %)\n", - "camera_1_progress (00:05:10): 804 / 918 seconds (87.6 %)\n", - "camera_3_progress (00:05:10): 803 / 918 seconds (87.5 %)\n", - "camera_0_progress (00:05:10): 804 / 919 seconds (87.5 %)\n", - "camera_2_progress (00:05:10): 804 / 918 seconds (87.6 %)\n", - "camera_1_progress (00:05:11): 806 / 918 seconds (87.8 %)\n", - "camera_3_progress (00:05:11): 806 / 918 seconds (87.8 %)\n", - "camera_0_progress (00:05:11): 807 / 919 seconds (87.8 %)\n", - "camera_2_progress (00:05:11): 806 / 918 seconds (87.8 %)\n", - "camera_0_progress (00:05:12): 809 / 919 seconds (88.0 %)\n", - "camera_2_progress (00:05:12): 808 / 918 seconds (88.0 %)\n", - "camera_1_progress (00:05:12): 809 / 918 seconds (88.1 %)\n", - "camera_3_progress (00:05:12): 808 / 918 seconds (88.0 %)\n", - "camera_0_progress (00:05:13): 812 / 919 seconds (88.4 %)\n", - "camera_2_progress (00:05:13): 811 / 918 seconds (88.3 %)\n", - "camera_1_progress (00:05:13): 811 / 918 seconds (88.3 %)\n", - "camera_3_progress (00:05:13): 811 / 918 seconds (88.3 %)\n", - "camera_2_progress (00:05:14): 814 / 918 seconds (88.7 %)\n", - "camera_1_progress (00:05:14): 814 / 918 seconds (88.7 %)\n", - "camera_3_progress (00:05:14): 813 / 918 seconds (88.6 %)\n", - "camera_0_progress (00:05:14): 814 / 919 seconds (88.6 %)\n", - "camera_2_progress (00:05:15): 816 / 918 seconds (88.9 %)\n", - "camera_1_progress (00:05:15): 816 / 918 seconds (88.9 %)\n", - "camera_3_progress (00:05:15): 816 / 918 seconds (88.9 %)\n", - "camera_0_progress (00:05:15): 817 / 919 seconds (88.9 %)\n", - "camera_3_progress (00:05:16): 818 / 918 seconds (89.1 %)\n", - "camera_0_progress (00:05:16): 819 / 919 seconds (89.1 %)\n", - "camera_2_progress (00:05:16): 819 / 918 seconds (89.2 %)\n", - "camera_1_progress (00:05:16): 819 / 918 seconds (89.2 %)\n", - "camera_0_progress (00:05:17): 822 / 919 seconds (89.4 %)\n", - "camera_2_progress (00:05:17): 821 / 918 seconds (89.4 %)\n", - "camera_1_progress (00:05:17): 821 / 918 seconds (89.4 %)\n", - "camera_3_progress (00:05:17): 821 / 918 seconds (89.4 %)\n", - "camera_1_progress (00:05:18): 824 / 918 seconds (89.8 %)\n", - "camera_3_progress (00:05:18): 823 / 918 seconds (89.7 %)\n", - "camera_0_progress (00:05:18): 824 / 919 seconds (89.7 %)\n", - "camera_2_progress (00:05:18): 824 / 918 seconds (89.8 %)\n", - "camera_1_progress (00:05:19): 826 / 918 seconds (90.0 %)\n", - "camera_3_progress (00:05:19): 825 / 918 seconds (89.9 %)\n", - "camera_0_progress (00:05:19): 826 / 919 seconds (89.9 %)\n", - "camera_2_progress (00:05:19): 826 / 918 seconds (90.0 %)\n", - "camera_1_progress (00:05:20): 828 / 918 seconds (90.2 %)\n", - "camera_3_progress (00:05:20): 828 / 918 seconds (90.2 %)\n", - "camera_0_progress (00:05:20): 829 / 919 seconds (90.2 %)\n", - "camera_2_progress (00:05:20): 828 / 918 seconds (90.2 %)\n", - "camera_2_progress (00:05:21): 831 / 918 seconds (90.5 %)\n", - "camera_1_progress (00:05:21): 831 / 918 seconds (90.5 %)\n", - "camera_3_progress (00:05:21): 830 / 918 seconds (90.4 %)\n", - "camera_0_progress (00:05:21): 831 / 919 seconds (90.4 %)\n", - "camera_3_progress (00:05:22): 833 / 918 seconds (90.7 %)\n", - "camera_0_progress (00:05:22): 834 / 919 seconds (90.8 %)\n", - "camera_2_progress (00:05:22): 833 / 918 seconds (90.7 %)\n", - "camera_1_progress (00:05:22): 833 / 918 seconds (90.7 %)\n", - "camera_0_progress (00:05:23): 836 / 919 seconds (91.0 %)\n", - "camera_2_progress (00:05:23): 835 / 918 seconds (91.0 %)\n", - "camera_1_progress (00:05:23): 836 / 918 seconds (91.1 %)\n", - "camera_3_progress (00:05:23): 835 / 918 seconds (91.0 %)\n", - "camera_0_progress (00:05:24): 838 / 919 seconds (91.2 %)\n", - "camera_2_progress (00:05:24): 838 / 918 seconds (91.3 %)\n", - "camera_1_progress (00:05:24): 838 / 918 seconds (91.3 %)\n", - "camera_3_progress (00:05:24): 838 / 918 seconds (91.3 %)\n", - "camera_3_progress (00:05:25): 840 / 918 seconds (91.5 %)\n", - "camera_0_progress (00:05:25): 841 / 919 seconds (91.5 %)\n", - "camera_2_progress (00:05:25): 840 / 918 seconds (91.5 %)\n", - "camera_1_progress (00:05:25): 840 / 918 seconds (91.5 %)\n", - "camera_2_progress (00:05:26): 843 / 918 seconds (91.8 %)\n", - "camera_1_progress (00:05:26): 843 / 918 seconds (91.8 %)\n", - "camera_3_progress (00:05:26): 842 / 918 seconds (91.7 %)\n", - "camera_0_progress (00:05:26): 843 / 919 seconds (91.7 %)\n", - "camera_2_progress (00:05:27): 845 / 918 seconds (92.0 %)\n", - "camera_1_progress (00:05:27): 845 / 918 seconds (92.0 %)\n", - "camera_3_progress (00:05:27): 845 / 918 seconds (92.0 %)\n", - "camera_0_progress (00:05:27): 846 / 919 seconds (92.1 %)\n", - "camera_2_progress (00:05:28): 848 / 918 seconds (92.4 %)\n", - "camera_1_progress (00:05:28): 848 / 918 seconds (92.4 %)\n", - "camera_3_progress (00:05:28): 847 / 918 seconds (92.3 %)\n", - "camera_0_progress (00:05:28): 848 / 919 seconds (92.3 %)\n", - "camera_2_progress (00:05:29): 850 / 918 seconds (92.6 %)\n", - "camera_1_progress (00:05:29): 850 / 918 seconds (92.6 %)\n", - "camera_3_progress (00:05:29): 850 / 918 seconds (92.6 %)\n", - "camera_0_progress (00:05:29): 851 / 919 seconds (92.6 %)\n", - "camera_0_progress (00:05:30): 853 / 919 seconds (92.8 %)\n", - "camera_2_progress (00:05:30): 853 / 918 seconds (92.9 %)\n", - "camera_1_progress (00:05:30): 853 / 918 seconds (92.9 %)\n", - "camera_3_progress (00:05:30): 852 / 918 seconds (92.8 %)\n", - "camera_1_progress (00:05:31): 856 / 918 seconds (93.2 %)\n", - "camera_3_progress (00:05:31): 855 / 918 seconds (93.1 %)\n", - "camera_0_progress (00:05:31): 856 / 919 seconds (93.1 %)\n", - "camera_2_progress (00:05:31): 856 / 918 seconds (93.2 %)\n", - "camera_1_progress (00:05:32): 858 / 918 seconds (93.5 %)\n", - "camera_3_progress (00:05:32): 858 / 918 seconds (93.5 %)\n", - "camera_0_progress (00:05:32): 859 / 919 seconds (93.5 %)\n", - "camera_2_progress (00:05:32): 858 / 918 seconds (93.5 %)\n", - "camera_0_progress (00:05:33): 861 / 919 seconds (93.7 %)\n", - "camera_2_progress (00:05:33): 860 / 918 seconds (93.7 %)\n", - "camera_3_progress (00:05:33): 860 / 918 seconds (93.7 %)\n", - "camera_1_progress (00:05:33): 861 / 918 seconds (93.8 %)\n", - "camera_0_progress (00:05:34): 864 / 919 seconds (94.0 %)\n", - "camera_2_progress (00:05:34): 863 / 918 seconds (94.0 %)\n", - "camera_1_progress (00:05:34): 863 / 918 seconds (94.0 %)\n", - "camera_3_progress (00:05:34): 863 / 918 seconds (94.0 %)\n", - "camera_2_progress (00:05:35): 865 / 918 seconds (94.2 %)\n", - "camera_1_progress (00:05:35): 866 / 918 seconds (94.3 %)\n", - "camera_3_progress (00:05:35): 865 / 918 seconds (94.2 %)\n", - "camera_0_progress (00:05:35): 866 / 919 seconds (94.2 %)\n", - "camera_0_progress (00:05:36): 869 / 919 seconds (94.6 %)\n", - "camera_2_progress (00:05:36): 868 / 918 seconds (94.6 %)\n", - "camera_1_progress (00:05:36): 868 / 918 seconds (94.6 %)\n", - "camera_3_progress (00:05:36): 868 / 918 seconds (94.6 %)\n", - "camera_3_progress (00:05:37): 870 / 918 seconds (94.8 %)\n", - "camera_0_progress (00:05:37): 871 / 919 seconds (94.8 %)\n", - "camera_2_progress (00:05:37): 871 / 918 seconds (94.9 %)\n", - "camera_1_progress (00:05:37): 871 / 918 seconds (94.9 %)\n", - "camera_3_progress (00:05:38): 873 / 918 seconds (95.1 %)\n", - "camera_0_progress (00:05:38): 874 / 919 seconds (95.1 %)\n", - "camera_2_progress (00:05:38): 873 / 918 seconds (95.1 %)\n", - "camera_1_progress (00:05:38): 874 / 918 seconds (95.2 %)\n", - "camera_0_progress (00:05:39): 876 / 919 seconds (95.3 %)\n", - "camera_2_progress (00:05:39): 876 / 918 seconds (95.4 %)\n", - "camera_1_progress (00:05:39): 876 / 918 seconds (95.4 %)\n", - "camera_3_progress (00:05:39): 876 / 918 seconds (95.4 %)\n", - "camera_0_progress (00:05:40): 879 / 919 seconds (95.6 %)\n", - "camera_2_progress (00:05:40): 878 / 918 seconds (95.6 %)\n", - "camera_1_progress (00:05:40): 878 / 918 seconds (95.6 %)\n", - "camera_3_progress (00:05:40): 878 / 918 seconds (95.6 %)\n", - "camera_1_progress (00:05:41): 881 / 918 seconds (96.0 %)\n", - "camera_3_progress (00:05:41): 880 / 918 seconds (95.9 %)\n", - "camera_0_progress (00:05:41): 881 / 919 seconds (95.9 %)\n", - "camera_2_progress (00:05:41): 881 / 918 seconds (96.0 %)\n", - "camera_1_progress (00:05:42): 884 / 918 seconds (96.3 %)\n", - "camera_3_progress (00:05:42): 883 / 918 seconds (96.2 %)\n", - "camera_0_progress (00:05:42): 884 / 919 seconds (96.2 %)\n", - "camera_2_progress (00:05:42): 883 / 918 seconds (96.2 %)\n", - "camera_1_progress (00:05:43): 886 / 918 seconds (96.5 %)\n", - "camera_3_progress (00:05:43): 886 / 918 seconds (96.5 %)\n", - "camera_0_progress (00:05:43): 887 / 919 seconds (96.5 %)\n", - "camera_2_progress (00:05:43): 886 / 918 seconds (96.5 %)\n", - "camera_3_progress (00:05:44): 888 / 918 seconds (96.7 %)\n", - "camera_0_progress (00:05:44): 889 / 919 seconds (96.7 %)\n", - "camera_2_progress (00:05:44): 889 / 918 seconds (96.8 %)\n", - "camera_1_progress (00:05:44): 889 / 918 seconds (96.8 %)\n", - "camera_2_progress (00:05:45): 891 / 918 seconds (97.1 %)\n", - "camera_1_progress (00:05:45): 891 / 918 seconds (97.1 %)\n", - "camera_3_progress (00:05:45): 891 / 918 seconds (97.1 %)\n", - "camera_0_progress (00:05:45): 892 / 919 seconds (97.1 %)\n", - "camera_0_progress (00:05:46): 894 / 919 seconds (97.3 %)\n", - "camera_2_progress (00:05:46): 893 / 918 seconds (97.3 %)\n", - "camera_1_progress (00:05:46): 894 / 918 seconds (97.4 %)\n", - "camera_3_progress (00:05:46): 893 / 918 seconds (97.3 %)\n", - "camera_0_progress (00:05:47): 897 / 919 seconds (97.6 %)\n", - "camera_2_progress (00:05:47): 896 / 918 seconds (97.6 %)\n", - "camera_1_progress (00:05:47): 896 / 918 seconds (97.6 %)\n", - "camera_3_progress (00:05:47): 896 / 918 seconds (97.6 %)\n", - "camera_3_progress (00:05:48): 899 / 918 seconds (97.9 %)\n", - "camera_0_progress (00:05:48): 900 / 919 seconds (97.9 %)\n", - "camera_2_progress (00:05:48): 899 / 918 seconds (97.9 %)\n", - "camera_1_progress (00:05:48): 899 / 918 seconds (97.9 %)\n", - "camera_2_progress (00:05:49): 902 / 918 seconds (98.3 %)\n", - "camera_1_progress (00:05:49): 902 / 918 seconds (98.3 %)\n", - "camera_3_progress (00:05:49): 901 / 918 seconds (98.1 %)\n", - "camera_0_progress (00:05:49): 902 / 919 seconds (98.2 %)\n", - "camera_0_progress (00:05:50): 906 / 919 seconds (98.6 %)\n", - "camera_2_progress (00:05:50): 905 / 918 seconds (98.6 %)\n", - "camera_1_progress (00:05:50): 905 / 918 seconds (98.6 %)\n", - "camera_3_progress (00:05:50): 905 / 918 seconds (98.6 %)\n", - "camera_1_progress (00:05:51): 908 / 918 seconds (98.9 %)\n", - "camera_3_progress (00:05:51): 908 / 918 seconds (98.9 %)\n", - "camera_0_progress (00:05:51): 909 / 919 seconds (98.9 %)\n", - "camera_2_progress (00:05:51): 908 / 918 seconds (98.9 %)\n", - "camera_0_progress (00:05:52): 913 / 919 seconds (99.3 %)\n", - "camera_2_progress (00:05:52): 912 / 918 seconds (99.3 %)\n", - "camera_1_progress (00:05:52): 912 / 918 seconds (99.3 %)\n", - "camera_3_progress (00:05:52): 912 / 918 seconds (99.3 %)\n", - "camera_3_progress (00:05:53): 914 / 918 seconds (99.6 %)\n", - "camera_0_progress (00:05:53): 915 / 919 seconds (99.6 %)\n", - "camera_2_progress (00:05:53): 915 / 918 seconds (99.7 %)\n", - "camera_1_progress (00:05:53): 915 / 918 seconds (99.7 %)\n", - "camera_0_progress (00:05:54): 918 / 919 seconds (99.9 %)\n", - "camera_2_progress (00:05:54): 917 / 918 seconds (99.9 %)\n", - "camera_1_progress (00:05:54): 917 / 918 seconds (99.9 %)\n", - "camera_3_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", - "camera_3_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", - "camera_2_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", - "camera_0_progress (00:05:54): 919 / 919 seconds (100.0 %)\n", - "camera_1_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", - "Pipeline camera_2 finished.\n", - "Pipeline camera_0 finished.\n", - "Pipeline camera_3 finished.\n", - "Pipeline camera_1 finished.\n", - "All pipelines finished successfully.\n" - ] - } - ], - "source": [ - "pipelines = trace_config(cfg)\n", - "\n", - "for pipeline in pipelines:\n", - " pipeline.start()\n", - "for pipeline in pipelines:\n", - " pipeline.join()\n", - "\n", - "print(\"All pipelines finished successfully.\")" - ] - } - ], - "metadata": { - "kernelspec": { - "display_name": "BagX", - "language": "python", - "name": "python3" - }, - "language_info": { - "codemirror_mode": { - "name": "ipython", - "version": 3 - }, - "file_extension": ".py", - "mimetype": "text/x-python", - "name": "python", - "nbconvert_exporter": "python", - "pygments_lexer": "ipython3", - "version": "3.8.16" - }, - "orig_nbformat": 4 - }, - "nbformat": 4, - "nbformat_minor": 2 + "cells": [ + { + "cell_type": "code", + "execution_count": 1, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "/usr/bin/zsh\n", + "/opt/ros/noetic/etc/catkin/profile.d/50-rosmon.zsh:66: command not found: compdef\n" + ] + } + ], + "source": [ + "# =============================================================================\n", + "# Created on Wed Jun 07 2023 16:09:02\n", + "# Author: Mukai (Tom Notch) Yu\n", + "# Email: mukaiy@andrew.cmu.edu\n", + "# Affiliation: Carnegie Mellon University, Robotics Institute, the AirLab\n", + "#\n", + "# Copyright Ⓒ 2023 Mukai (Tom Notch) Yu\n", + "# =============================================================================\n", + "\n", + "\n", + "! echo $SHELL\n", + "! source /opt/ros/noetic/setup.zsh" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "metadata": {}, + "outputs": [], + "source": [ + "import gi\n", + "\n", + "gi.require_version(\"Gst\", \"1.0\")\n", + "from gi.repository import Gst\n", + "from sensor_msgs.msg import Image\n", + "import cv2\n", + "import numpy as np\n", + "import os\n", + "import re\n", + "import rosbag\n", + "import rospy\n", + "import time\n", + "import threading\n", + "import yaml" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": {}, + "outputs": [], + "source": [ + "file_type_to_extension = {\n", + " \"mp4\": \".mp4\",\n", + " \"rosbag\": \".bag\",\n", + " \"directory\": \"\",\n", + " \"YAML\": \".yaml\",\n", + "}" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": {}, + "outputs": [], + "source": [ + "def load_config(cfg_path: str) -> dict:\n", + " with open(cfg_path) as f:\n", + " cfg: dict = yaml.safe_load(f)\n", + " return cfg\n", + "\n", + "\n", + "def print_dict(d: dict, indent: int = 0):\n", + " for key, value in d.items():\n", + " if isinstance(value, dict):\n", + " print(\" \" * indent + str(key) + \": \")\n", + " print_dict(value, indent + 1)\n", + " else:\n", + " print(\" \" * indent + str(key) + \": \" + str(value))" + ] + }, + { + "cell_type": "code", + "execution_count": 5, + "metadata": {}, + "outputs": [], + "source": [ + "class ImgDirOutput:\n", + " def __init__(self, name: str, output: dict):\n", + " self.name = name\n", + " self.path = output[\"path\"]\n", + " self.directory = output[\"directory\"]\n", + "\n", + " assert (\n", + " output[\"type\"] == \"directory\"\n", + " ), f'{self.name}\\'s output type {output[\"type\"]} is inappropriate for ImgDirOutput Class.'\n", + "\n", + " def callback(self, image, time_stamp: int) -> None:\n", + " output_image = cv2.cvtColor(image, cv2.COLOR_RGB2BGR)\n", + " cv2.imwrite(\n", + " os.path.join(self.directory, str(time_stamp) + \".png\"), output_image\n", + " )\n", + "\n", + " def close(self) -> None:\n", + " pass" + ] + }, + { + "cell_type": "code", + "execution_count": 6, + "metadata": {}, + "outputs": [], + "source": [ + "class RosbagOutput:\n", + " def __init__(self, name: str, output: dict):\n", + " self.name = name\n", + " self.path = output[\"path\"]\n", + " self.directory = output[\"directory\"]\n", + " self.topic = output[\"topic\"]\n", + " self.frame_id = output.get(\"frame_id\", None)\n", + "\n", + " assert (\n", + " output[\"type\"] == \"rosbag\"\n", + " ), f'{self.name}\\'s output type {output[\"type\"]} is inappropriate for RosbagOutput Class.'\n", + "\n", + " self.init_rosbag()\n", + "\n", + " def init_rosbag(self) -> None:\n", + " self.bag = rosbag.Bag(self.path, \"w\")\n", + "\n", + " self.image_msg = Image()\n", + " if self.frame_id is not None:\n", + " self.image_msg.header.frame_id = self.frame_id\n", + " self.image_msg.encoding = \"rgb8\"\n", + " self.image_msg.header.seq = -1\n", + "\n", + " def callback(self, image, time_stamp: int) -> None:\n", + " self.image_msg.header.stamp = rospy.Time(\n", + " secs=int(time_stamp // 1e9), nsecs=int(time_stamp % 1e9)\n", + " )\n", + " self.image_msg.header.seq += 1\n", + " self.image_msg.height = image.shape[0]\n", + " self.image_msg.width = image.shape[1]\n", + " self.image_msg.step = self.image_msg.width * 3\n", + " self.image_msg.data = image.tobytes()\n", + "\n", + " self.bag.write(self.topic, self.image_msg, t=self.image_msg.header.stamp)\n", + "\n", + " def close(self) -> None:\n", + " self.bag.close()" + ] + }, + { + "cell_type": "code", + "execution_count": 7, + "metadata": {}, + "outputs": [], + "source": [ + "class MP4Input:\n", + " def __init__(self, name: str, input: dict, outputs: dict):\n", + " \"\"\"initialize the MP4Input class\n", + "\n", + " Args:\n", + " name (str): name of this pipeline in the yaml config, used in named sink of gstreamer pipeline\n", + " input (dict): input config\n", + " output (list): list of output class instances, this input class only uses their callback functions\n", + " \"\"\"\n", + " Gst.init(None)\n", + " self.name = name\n", + " self.path = input[\"path\"]\n", + " if not input[\"type\"] == \"mp4\": # verify type is correct\n", + " raise ValueError(\n", + " f'Input type {input[\"type\"]} is inappropriate for MP4Input Class.'\n", + " )\n", + "\n", + " self.width = input.get(\"width\", None)\n", + " self.height = input.get(\"height\", None)\n", + " self.start = input.get(\"start\", None)\n", + " self.end = input.get(\"end\", None)\n", + " self.output_callbacks = [output.callback for output in outputs.values()]\n", + " self.close_handlers = [output.close for output in outputs.values()]\n", + "\n", + " self.setup()\n", + "\n", + " def setup(self):\n", + " self.parse_start_time()\n", + "\n", + " self.bytes_per_pixel = 3 # since it's in RGB format\n", + " self.current_relative_time = 0\n", + "\n", + " # setup gstreamer pipeline\n", + " self.gstreamer_pipeline_str = (\n", + " \"filesrc location=\"\n", + " + self.path\n", + " + \" ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB\"\n", + " )\n", + " if self.width:\n", + " self.gstreamer_pipeline_str += \",width=\" + str(self.width)\n", + " if self.height:\n", + " self.gstreamer_pipeline_str += \",height=\" + str(self.height)\n", + " self.gstreamer_pipeline_str += (\n", + " \" ! progressreport update-freq=1 name=\"\n", + " + self.name\n", + " + \"_progress ! fakesink name=\"\n", + " + self.name\n", + " )\n", + " print(\n", + " self.name\n", + " + \" MP4Input's gstreamer pipeline string: \"\n", + " + self.gstreamer_pipeline_str\n", + " )\n", + " self.gstreamer_pipeline = Gst.parse_launch(self.gstreamer_pipeline_str)\n", + " self.gstreamer_pipeline.get_by_name(self.name).get_static_pad(\"sink\").add_probe(\n", + " Gst.PadProbeType.BUFFER, self.callback\n", + " )\n", + "\n", + " def parse_start_time(self):\n", + " \"\"\"parse the absolute start time in nanoseconds from the file name\"\"\"\n", + " match = re.search(r\"(\\d{10}_\\d{9})(?=\\.\\w+$)\", self.path)\n", + " assert (\n", + " match is not None\n", + " ), f\"{self.path} does not contain the proper timestamp sub-string.\"\n", + " time_str = match[1].split(\"_\")\n", + " self.absolute_start_time = int(time_str[0]) * int(1e9) + int(time_str[1])\n", + "\n", + " def callback(self, pad, info):\n", + " image, self.current_relative_time = self.get_frame(pad, info)\n", + "\n", + " # check if the current frame is within the start and end time\n", + " if (self.start and self.current_relative_time * 1e-9 < self.start) or (\n", + " self.end and self.current_relative_time * 1e-9 > self.end\n", + " ):\n", + " return Gst.PadProbeReturn.OK\n", + "\n", + " current_absolute_time = self.absolute_start_time + self.current_relative_time\n", + "\n", + " # calling callbacks for each output pipeline\n", + " for callback in self.output_callbacks:\n", + " callback(image, current_absolute_time)\n", + "\n", + " return Gst.PadProbeReturn.OK\n", + "\n", + " def get_frame(self, pad, info):\n", + " buffer = info.get_buffer()\n", + " caps = pad.get_current_caps()\n", + "\n", + " caps_structure = caps.get_structure(0)\n", + " height, width = caps_structure.get_value(\"height\"), caps_structure.get_value(\n", + " \"width\"\n", + " )\n", + "\n", + " is_mapped, map_info = buffer.map(Gst.MapFlags.READ)\n", + " if is_mapped:\n", + " try:\n", + " image = np.ndarray(\n", + " (height, width, self.bytes_per_pixel),\n", + " dtype=\"uint8\",\n", + " buffer=map_info.data,\n", + " ).copy() # extend array lifetime beyond subsequent unmap\n", + " finally:\n", + " buffer.unmap(map_info)\n", + "\n", + " return (\n", + " image,\n", + " buffer.pts,\n", + " ) # using pts instead of dts since it's set in the mp4 file recorded using https://bitbucket.org/castacks/image_sharing/src/c5ab07622155793ff756020d1a8117a7d5036325/src/tools/to_gstreamer.cpp#lines-156\n", + "\n", + " def loop(self):\n", + " self.gstreamer_pipeline.set_state(Gst.State.PLAYING)\n", + "\n", + " try:\n", + " while True:\n", + " msg = self.gstreamer_pipeline.get_bus().timed_pop_filtered(\n", + " Gst.SECOND * 5, Gst.MessageType.EOS | Gst.MessageType.ERROR\n", + " ) #! 5 seconds timeout\n", + "\n", + " if msg:\n", + " if msg.type == Gst.MessageType.EOS:\n", + " break\n", + " elif msg.type == Gst.MessageType.ERROR:\n", + " raise Exception(\n", + " \"GStreamer stream Error occurred in pipeline: \" + self.name\n", + " )\n", + "\n", + " # # Query position and duration to display progress\n", + " # success, position = self.gstreamer_pipeline.query_position(Gst.Format.TIME)\n", + " # success, duration = self.gstreamer_pipeline.query_duration(Gst.Format.TIME)\n", + "\n", + " # if success and duration != Gst.CLOCK_TIME_NONE and duration != 0:\n", + " # progress = (position / duration) * 100\n", + " # print(f\"{self.name}\\'s progress: {progress:.2f}%\")\n", + "\n", + " #! delay for 5 seconds since the progress query is blocking\n", + " time.sleep(5)\n", + " finally:\n", + " self.gstreamer_pipeline.set_state(Gst.State.NULL)\n", + "\n", + " # call close handlers for each output pipeline\n", + " for close_handler in self.close_handlers:\n", + " close_handler()\n", + " print(f\"Pipeline {self.name} finished.\")" + ] + }, + { + "cell_type": "code", + "execution_count": 8, + "metadata": {}, + "outputs": [], + "source": [ + "class Pipeline(threading.Thread):\n", + " def __init__(self, name: str, pipeline: dict):\n", + " super().__init__()\n", + " self.name = name\n", + " self.outputs = self.init_outputs(pipeline[\"output\"])\n", + " self.input = self.init_input(pipeline[\"input\"])\n", + "\n", + " def init_outputs(self, outputs_dict: dict):\n", + " outputs = {}\n", + " for (\n", + " name,\n", + " output,\n", + " ) in outputs_dict.items(): # name is arbitrary and doesn't matter\n", + " output_type = output[\"type\"]\n", + " assert (\n", + " output_type in file_type_to_extension.keys()\n", + " ), f\"pipeline {self.name} output's file type {output_type} is not supported\"\n", + " if output_type == \"directory\":\n", + " outputs[name] = ImgDirOutput(name, output)\n", + " elif output_type == \"rosbag\":\n", + " outputs[name] = RosbagOutput(name, output)\n", + " return outputs\n", + "\n", + " def init_input(self, input_dict: dict):\n", + " assert (\n", + " input_dict[\"type\"] in file_type_to_extension.keys()\n", + " ), f'pipeline {self.name} input\\'s file type {input_dict[\"type\"]} is not supported'\n", + " if input_dict[\"type\"] == \"mp4\":\n", + " return MP4Input(self.name, input_dict, self.outputs)\n", + "\n", + " def run(self):\n", + " print(f\"{self.name} pipeline started.\")\n", + " self.input.loop()" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": {}, + "outputs": [], + "source": [ + "def verify_file(path: str, type: str) -> bool:\n", + " # verify the file/directory exists\n", + " assert os.path.exists(path), f\"file {path} does not exist\"\n", + "\n", + " # verify the file type is supported\n", + " assert type in file_type_to_extension.keys(), f\"file type {type} is not supported\"\n", + "\n", + " # verify the file type matches the extension or the path is a directory\n", + " if type == \"directory\":\n", + " assert os.path.isdir(path), f\"{path} is not a directory\"\n", + " else:\n", + " assert (\n", + " os.path.splitext(path)[-1] == file_type_to_extension[type]\n", + " ), f\"file {path} is not a {type} file\"\n", + "\n", + " return True\n", + "\n", + "\n", + "def trace_config(cfg: dict):\n", + " pipelines = []\n", + " # verify that the config file contains \"pipelines\"\n", + " assert (\n", + " \"pipelines\" in cfg and cfg[\"pipelines\"]\n", + " ), \"pipeline is not specified in config file\"\n", + "\n", + " print(\"Loaded config:\")\n", + " print(\"pipelines: \", end=\"\")\n", + " print(cfg[\"pipelines\"], end=\"\\n\\n\")\n", + "\n", + " for pipeline_name in cfg[\"pipelines\"]:\n", + " # verify that the pipeline is specified in the config file\n", + " assert (\n", + " pipeline_name in cfg\n", + " ), f\"pipeline {pipeline_name} is not specified in config file\"\n", + "\n", + " pipeline = cfg[pipeline_name]\n", + "\n", + " # make directories for output and verify type\n", + " for index, output in pipeline[\"output\"].items():\n", + " # verify the file type is supported\n", + " assert (\n", + " output[\"type\"] in file_type_to_extension.keys()\n", + " ), f'pipeline {pipeline_name}\\'s output {index}\\'s file type {output[\"type\"]} is not supported'\n", + "\n", + " # make parent directories if they don't exist\n", + " output[\"directory\"] = (\n", + " os.path.dirname(output[\"path\"])\n", + " if (output[\"type\"] == \"directory\")\n", + " else os.path.dirname(output[\"path\"])\n", + " )\n", + " os.makedirs(output[\"directory\"], exist_ok=True)\n", + "\n", + " # verify input\n", + " assert verify_file(\n", + " path=pipeline[\"input\"][\"path\"], type=pipeline[\"input\"][\"type\"]\n", + " ), f'pipeline {pipeline_name}\\'s input file {pipeline[\"input\"][\"path\"]} is not valid'\n", + "\n", + " print(pipeline_name + \":\")\n", + " print_dict(pipeline, indent=1)\n", + "\n", + " pipelines.append(Pipeline(pipeline_name, pipeline))\n", + "\n", + " return pipelines" + ] + }, + { + "cell_type": "code", + "execution_count": 10, + "metadata": {}, + "outputs": [], + "source": [ + "cfg_path = \"./config/wildfire/subcanopy/mp4_to_imgdir_rosbag.yaml\"\n", + "\n", + "cfg = load_config(cfg_path)" + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Loaded config:\n", + "pipelines: ['camera_0', 'camera_1', 'camera_2', 'camera_3']\n", + "\n", + "camera_0:\n", + " input: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_0_1677761985_629121776.mp4\n", + " type: mp4\n", + " width: 612\n", + " height: 514\n", + " output: \n", + " 2: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_0.bag\n", + " type: rosbag\n", + " topic: /camera_0\n", + " frame_id: camera_0/optical_frame\n", + " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", + "camera_0 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_0_1677761985_629121776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_0_progress ! fakesink name=camera_0\n", + "camera_1:\n", + " input: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_1_1677761985_962133776.mp4\n", + " type: mp4\n", + " width: 612\n", + " height: 514\n", + " output: \n", + " 2: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_1.bag\n", + " type: rosbag\n", + " topic: /camera_1\n", + " frame_id: camera_1/optical_frame\n", + " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", + "camera_1 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_1_1677761985_962133776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_1_progress ! fakesink name=camera_1\n", + "camera_2:\n", + " input: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_2_1677761986_311796776.mp4\n", + " type: mp4\n", + " width: 612\n", + " height: 514\n", + " output: \n", + " 2: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_2.bag\n", + " type: rosbag\n", + " topic: /camera_2\n", + " frame_id: camera_2/optical_frame\n", + " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", + "camera_2 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_2_1677761986_311796776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_2_progress ! fakesink name=camera_2\n", + "camera_3:\n", + " input: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_3_1677761986_644808776.mp4\n", + " type: mp4\n", + " width: 612\n", + " height: 514\n", + " output: \n", + " 2: \n", + " path: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_3.bag\n", + " type: rosbag\n", + " topic: /camera_3\n", + " frame_id: camera_3/optical_frame\n", + " directory: /root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1\n", + "camera_3 MP4Input's gstreamer pipeline string: filesrc location=/root/data/wildfire/subcanopy/2023-04-27_FIRE-SGL-228/1/camera_3_1677761986_644808776.mp4 ! decodebin ! nvvideoconvert ! video/x-raw,format=RGB,width=612,height=514 ! progressreport update-freq=1 name=camera_3_progress ! fakesink name=camera_3\n", + "camera_0 pipeline started.\n", + "camera_1 pipeline started.\n", + "camera_2 pipeline started.\n", + "camera_3 pipeline started.\n", + "camera_3_progress (00:00:01): 0 / 918 seconds ( 0.0 %)\n", + "camera_0_progress (00:00:01): 1 / 919 seconds ( 0.1 %)\n", + "camera_2_progress (00:00:01): 0 / 918 seconds ( 0.0 %)\n", + "camera_1_progress (00:00:01): 0 / 918 seconds ( 0.0 %)\n", + "camera_1_progress (00:00:02): 5 / 918 seconds ( 0.5 %)\n", + "camera_3_progress (00:00:02): 4 / 918 seconds ( 0.4 %)\n", + "camera_0_progress (00:00:02): 5 / 919 seconds ( 0.5 %)\n", + "camera_2_progress (00:00:02): 5 / 918 seconds ( 0.5 %)\n", + "camera_2_progress (00:00:03): 8 / 918 seconds ( 0.9 %)\n", + "camera_1_progress (00:00:03): 8 / 918 seconds ( 0.9 %)\n", + "camera_3_progress (00:00:03): 8 / 918 seconds ( 0.9 %)\n", + "camera_0_progress (00:00:03): 9 / 919 seconds ( 1.0 %)\n", + "camera_0_progress (00:00:04): 12 / 919 seconds ( 1.3 %)\n", + "camera_2_progress (00:00:04): 11 / 918 seconds ( 1.2 %)\n", + "camera_1_progress (00:00:04): 12 / 918 seconds ( 1.3 %)\n", + "camera_3_progress (00:00:04): 11 / 918 seconds ( 1.2 %)\n", + "camera_0_progress (00:00:05): 15 / 919 seconds ( 1.6 %)\n", + "camera_2_progress (00:00:05): 15 / 918 seconds ( 1.6 %)\n", + "camera_1_progress (00:00:05): 15 / 918 seconds ( 1.6 %)\n", + "camera_3_progress (00:00:05): 14 / 918 seconds ( 1.5 %)\n", + "camera_0_progress (00:00:06): 19 / 919 seconds ( 2.1 %)\n", + "camera_2_progress (00:00:06): 18 / 918 seconds ( 2.0 %)\n", + "camera_1_progress (00:00:06): 18 / 918 seconds ( 2.0 %)\n", + "camera_3_progress (00:00:06): 18 / 918 seconds ( 2.0 %)\n", + "camera_3_progress (00:00:07): 21 / 918 seconds ( 2.3 %)\n", + "camera_0_progress (00:00:07): 22 / 919 seconds ( 2.4 %)\n", + "camera_2_progress (00:00:07): 21 / 918 seconds ( 2.3 %)\n", + "camera_1_progress (00:00:07): 21 / 918 seconds ( 2.3 %)\n", + "camera_1_progress (00:00:08): 25 / 918 seconds ( 2.7 %)\n", + "camera_3_progress (00:00:08): 24 / 918 seconds ( 2.6 %)\n", + "camera_0_progress (00:00:08): 25 / 919 seconds ( 2.7 %)\n", + "camera_2_progress (00:00:08): 24 / 918 seconds ( 2.6 %)\n", + "camera_0_progress (00:00:09): 28 / 919 seconds ( 3.0 %)\n", + "camera_2_progress (00:00:09): 28 / 918 seconds ( 3.1 %)\n", + "camera_1_progress (00:00:09): 28 / 918 seconds ( 3.1 %)\n", + "camera_3_progress (00:00:09): 28 / 918 seconds ( 3.1 %)\n", + "camera_0_progress (00:00:10): 32 / 919 seconds ( 3.5 %)\n", + "camera_2_progress (00:00:10): 31 / 918 seconds ( 3.4 %)\n", + "camera_1_progress (00:00:10): 32 / 918 seconds ( 3.5 %)\n", + "camera_3_progress (00:00:10): 31 / 918 seconds ( 3.4 %)\n", + "camera_0_progress (00:00:11): 35 / 919 seconds ( 3.8 %)\n", + "camera_2_progress (00:00:11): 35 / 918 seconds ( 3.8 %)\n", + "camera_1_progress (00:00:11): 35 / 918 seconds ( 3.8 %)\n", + "camera_3_progress (00:00:11): 34 / 918 seconds ( 3.7 %)\n", + "camera_2_progress (00:00:12): 38 / 918 seconds ( 4.1 %)\n", + "camera_1_progress (00:00:12): 38 / 918 seconds ( 4.1 %)\n", + "camera_3_progress (00:00:12): 38 / 918 seconds ( 4.1 %)\n", + "camera_0_progress (00:00:12): 39 / 919 seconds ( 4.2 %)\n", + "camera_1_progress (00:00:13): 41 / 918 seconds ( 4.5 %)\n", + "camera_3_progress (00:00:13): 41 / 918 seconds ( 4.5 %)\n", + "camera_0_progress (00:00:13): 42 / 919 seconds ( 4.6 %)\n", + "camera_2_progress (00:00:13): 41 / 918 seconds ( 4.5 %)\n", + "camera_1_progress (00:00:14): 45 / 918 seconds ( 4.9 %)\n", + "camera_3_progress (00:00:14): 44 / 918 seconds ( 4.8 %)\n", + "camera_0_progress (00:00:14): 45 / 919 seconds ( 4.9 %)\n", + "camera_2_progress (00:00:14): 44 / 918 seconds ( 4.8 %)\n", + "camera_2_progress (00:00:15): 48 / 918 seconds ( 5.2 %)\n", + "camera_1_progress (00:00:15): 48 / 918 seconds ( 5.2 %)\n", + "camera_3_progress (00:00:15): 47 / 918 seconds ( 5.1 %)\n", + "camera_0_progress (00:00:15): 48 / 919 seconds ( 5.2 %)\n", + "camera_0_progress (00:00:16): 51 / 919 seconds ( 5.5 %)\n", + "camera_2_progress (00:00:16): 51 / 918 seconds ( 5.6 %)\n", + "camera_1_progress (00:00:16): 51 / 918 seconds ( 5.6 %)\n", + "camera_3_progress (00:00:16): 50 / 918 seconds ( 5.4 %)\n", + "camera_2_progress (00:00:17): 53 / 918 seconds ( 5.8 %)\n", + "camera_1_progress (00:00:17): 54 / 918 seconds ( 5.9 %)\n", + "camera_3_progress (00:00:17): 53 / 918 seconds ( 5.8 %)\n", + "camera_0_progress (00:00:17): 54 / 919 seconds ( 5.9 %)\n", + "camera_3_progress (00:00:18): 56 / 918 seconds ( 6.1 %)\n", + "camera_0_progress (00:00:18): 57 / 919 seconds ( 6.2 %)\n", + "camera_2_progress (00:00:18): 56 / 918 seconds ( 6.1 %)\n", + "camera_1_progress (00:00:18): 56 / 918 seconds ( 6.1 %)\n", + "camera_2_progress (00:00:19): 58 / 918 seconds ( 6.3 %)\n", + "camera_1_progress (00:00:19): 59 / 918 seconds ( 6.4 %)\n", + "camera_3_progress (00:00:19): 58 / 918 seconds ( 6.3 %)\n", + "camera_0_progress (00:00:19): 59 / 919 seconds ( 6.4 %)\n", + "camera_2_progress (00:00:20): 61 / 918 seconds ( 6.6 %)\n", + "camera_1_progress (00:00:20): 61 / 918 seconds ( 6.6 %)\n", + "camera_3_progress (00:00:20): 61 / 918 seconds ( 6.6 %)\n", + "camera_0_progress (00:00:20): 62 / 919 seconds ( 6.7 %)\n", + "camera_2_progress (00:00:21): 63 / 918 seconds ( 6.9 %)\n", + "camera_1_progress (00:00:21): 64 / 918 seconds ( 7.0 %)\n", + "camera_3_progress (00:00:21): 63 / 918 seconds ( 6.9 %)\n", + "camera_0_progress (00:00:21): 64 / 919 seconds ( 7.0 %)\n", + "camera_0_progress (00:00:22): 67 / 919 seconds ( 7.3 %)\n", + "camera_2_progress (00:00:22): 66 / 918 seconds ( 7.2 %)\n", + "camera_1_progress (00:00:22): 66 / 918 seconds ( 7.2 %)\n", + "camera_3_progress (00:00:22): 66 / 918 seconds ( 7.2 %)\n", + "camera_3_progress (00:00:23): 68 / 918 seconds ( 7.4 %)\n", + "camera_0_progress (00:00:23): 69 / 919 seconds ( 7.5 %)\n", + "camera_2_progress (00:00:23): 69 / 918 seconds ( 7.5 %)\n", + "camera_1_progress (00:00:23): 69 / 918 seconds ( 7.5 %)\n", + "camera_3_progress (00:00:24): 71 / 918 seconds ( 7.7 %)\n", + "camera_0_progress (00:00:24): 72 / 919 seconds ( 7.8 %)\n", + "camera_2_progress (00:00:24): 71 / 918 seconds ( 7.7 %)\n", + "camera_1_progress (00:00:24): 71 / 918 seconds ( 7.7 %)\n", + "camera_0_progress (00:00:25): 74 / 919 seconds ( 8.1 %)\n", + "camera_2_progress (00:00:25): 74 / 918 seconds ( 8.1 %)\n", + "camera_1_progress (00:00:25): 74 / 918 seconds ( 8.1 %)\n", + "camera_3_progress (00:00:25): 73 / 918 seconds ( 8.0 %)\n", + "camera_2_progress (00:00:26): 76 / 918 seconds ( 8.3 %)\n", + "camera_1_progress (00:00:26): 76 / 918 seconds ( 8.3 %)\n", + "camera_3_progress (00:00:26): 76 / 918 seconds ( 8.3 %)\n", + "camera_0_progress (00:00:26): 77 / 919 seconds ( 8.4 %)\n", + "camera_2_progress (00:00:27): 79 / 918 seconds ( 8.6 %)\n", + "camera_1_progress (00:00:27): 79 / 918 seconds ( 8.6 %)\n", + "camera_3_progress (00:00:27): 78 / 918 seconds ( 8.5 %)\n", + "camera_0_progress (00:00:27): 79 / 919 seconds ( 8.6 %)\n", + "camera_1_progress (00:00:28): 82 / 918 seconds ( 8.9 %)\n", + "camera_3_progress (00:00:28): 81 / 918 seconds ( 8.8 %)\n", + "camera_0_progress (00:00:28): 82 / 919 seconds ( 8.9 %)\n", + "camera_2_progress (00:00:28): 81 / 918 seconds ( 8.8 %)\n", + "camera_1_progress (00:00:29): 84 / 918 seconds ( 9.2 %)\n", + "camera_3_progress (00:00:29): 84 / 918 seconds ( 9.2 %)\n", + "camera_0_progress (00:00:29): 85 / 919 seconds ( 9.2 %)\n", + "camera_2_progress (00:00:29): 84 / 918 seconds ( 9.2 %)\n", + "camera_3_progress (00:00:30): 87 / 918 seconds ( 9.5 %)\n", + "camera_0_progress (00:00:30): 88 / 919 seconds ( 9.6 %)\n", + "camera_2_progress (00:00:30): 87 / 918 seconds ( 9.5 %)\n", + "camera_1_progress (00:00:30): 87 / 918 seconds ( 9.5 %)\n", + "camera_2_progress (00:00:31): 89 / 918 seconds ( 9.7 %)\n", + "camera_1_progress (00:00:31): 89 / 918 seconds ( 9.7 %)\n", + "camera_3_progress (00:00:31): 89 / 918 seconds ( 9.7 %)\n", + "camera_0_progress (00:00:31): 90 / 919 seconds ( 9.8 %)\n", + "camera_0_progress (00:00:32): 92 / 919 seconds (10.0 %)\n", + "camera_2_progress (00:00:32): 92 / 918 seconds (10.0 %)\n", + "camera_1_progress (00:00:32): 92 / 918 seconds (10.0 %)\n", + "camera_3_progress (00:00:32): 91 / 918 seconds ( 9.9 %)\n", + "camera_0_progress (00:00:33): 95 / 919 seconds (10.3 %)\n", + "camera_2_progress (00:00:33): 94 / 918 seconds (10.2 %)\n", + "camera_1_progress (00:00:33): 95 / 918 seconds (10.3 %)\n", + "camera_3_progress (00:00:33): 94 / 918 seconds (10.2 %)\n", + "camera_3_progress (00:00:34): 96 / 918 seconds (10.5 %)\n", + "camera_0_progress (00:00:34): 97 / 919 seconds (10.6 %)\n", + "camera_2_progress (00:00:34): 97 / 918 seconds (10.6 %)\n", + "camera_1_progress (00:00:34): 97 / 918 seconds (10.6 %)\n", + "camera_3_progress (00:00:35): 99 / 918 seconds (10.8 %)\n", + "camera_0_progress (00:00:35): 100 / 919 seconds (10.9 %)\n", + "camera_2_progress (00:00:35): 99 / 918 seconds (10.8 %)\n", + "camera_1_progress (00:00:35): 100 / 918 seconds (10.9 %)\n", + "camera_0_progress (00:00:36): 103 / 919 seconds (11.2 %)\n", + "camera_2_progress (00:00:36): 102 / 918 seconds (11.1 %)\n", + "camera_1_progress (00:00:36): 102 / 918 seconds (11.1 %)\n", + "camera_3_progress (00:00:36): 102 / 918 seconds (11.1 %)\n", + "camera_0_progress (00:00:37): 105 / 919 seconds (11.4 %)\n", + "camera_2_progress (00:00:37): 105 / 918 seconds (11.4 %)\n", + "camera_1_progress (00:00:37): 105 / 918 seconds (11.4 %)\n", + "camera_3_progress (00:00:37): 105 / 918 seconds (11.4 %)\n", + "camera_3_progress (00:00:38): 107 / 918 seconds (11.7 %)\n", + "camera_0_progress (00:00:38): 108 / 919 seconds (11.8 %)\n", + "camera_2_progress (00:00:38): 108 / 918 seconds (11.8 %)\n", + "camera_1_progress (00:00:38): 108 / 918 seconds (11.8 %)\n", + "camera_0_progress (00:00:39): 111 / 919 seconds (12.1 %)\n", + "camera_2_progress (00:00:39): 110 / 918 seconds (12.0 %)\n", + "camera_1_progress (00:00:39): 111 / 918 seconds (12.1 %)\n", + "camera_3_progress (00:00:39): 110 / 918 seconds (12.0 %)\n", + "camera_0_progress (00:00:40): 114 / 919 seconds (12.4 %)\n", + "camera_2_progress (00:00:40): 113 / 918 seconds (12.3 %)\n", + "camera_1_progress (00:00:40): 113 / 918 seconds (12.3 %)\n", + "camera_3_progress (00:00:40): 113 / 918 seconds (12.3 %)\n", + "camera_1_progress (00:00:41): 116 / 918 seconds (12.6 %)\n", + "camera_3_progress (00:00:41): 115 / 918 seconds (12.5 %)\n", + "camera_0_progress (00:00:41): 116 / 919 seconds (12.6 %)\n", + "camera_2_progress (00:00:41): 116 / 918 seconds (12.6 %)\n", + "camera_2_progress (00:00:42): 118 / 918 seconds (12.9 %)\n", + "camera_1_progress (00:00:42): 119 / 918 seconds (13.0 %)\n", + "camera_3_progress (00:00:42): 118 / 918 seconds (12.9 %)\n", + "camera_0_progress (00:00:42): 119 / 919 seconds (12.9 %)\n", + "camera_1_progress (00:00:43): 121 / 918 seconds (13.2 %)\n", + "camera_3_progress (00:00:43): 121 / 918 seconds (13.2 %)\n", + "camera_0_progress (00:00:43): 122 / 919 seconds (13.3 %)\n", + "camera_2_progress (00:00:43): 121 / 918 seconds (13.2 %)\n", + "camera_1_progress (00:00:44): 124 / 918 seconds (13.5 %)\n", + "camera_3_progress (00:00:44): 124 / 918 seconds (13.5 %)\n", + "camera_0_progress (00:00:44): 125 / 919 seconds (13.6 %)\n", + "camera_2_progress (00:00:44): 124 / 918 seconds (13.5 %)\n", + "camera_2_progress (00:00:45): 127 / 918 seconds (13.8 %)\n", + "camera_1_progress (00:00:45): 127 / 918 seconds (13.8 %)\n", + "camera_3_progress (00:00:45): 126 / 918 seconds (13.7 %)\n", + "camera_0_progress (00:00:45): 127 / 919 seconds (13.8 %)\n", + "camera_0_progress (00:00:46): 130 / 919 seconds (14.1 %)\n", + "camera_2_progress (00:00:46): 129 / 918 seconds (14.1 %)\n", + "camera_1_progress (00:00:46): 130 / 918 seconds (14.2 %)\n", + "camera_3_progress (00:00:46): 129 / 918 seconds (14.1 %)\n", + "camera_0_progress (00:00:47): 133 / 919 seconds (14.5 %)\n", + "camera_2_progress (00:00:47): 132 / 918 seconds (14.4 %)\n", + "camera_1_progress (00:00:47): 132 / 918 seconds (14.4 %)\n", + "camera_3_progress (00:00:47): 132 / 918 seconds (14.4 %)\n", + "camera_1_progress (00:00:48): 135 / 918 seconds (14.7 %)\n", + "camera_3_progress (00:00:48): 134 / 918 seconds (14.6 %)\n", + "camera_0_progress (00:00:48): 135 / 919 seconds (14.7 %)\n", + "camera_2_progress (00:00:48): 135 / 918 seconds (14.7 %)\n", + "camera_3_progress (00:00:49): 137 / 918 seconds (14.9 %)\n", + "camera_0_progress (00:00:49): 138 / 919 seconds (15.0 %)\n", + "camera_2_progress (00:00:49): 138 / 918 seconds (15.0 %)\n", + "camera_1_progress (00:00:49): 138 / 918 seconds (15.0 %)\n", + "camera_0_progress (00:00:50): 141 / 919 seconds (15.3 %)\n", + "camera_2_progress (00:00:50): 140 / 918 seconds (15.3 %)\n", + "camera_1_progress (00:00:50): 141 / 918 seconds (15.4 %)\n", + "camera_3_progress (00:00:50): 140 / 918 seconds (15.3 %)\n", + "camera_2_progress (00:00:51): 143 / 918 seconds (15.6 %)\n", + "camera_1_progress (00:00:51): 143 / 918 seconds (15.6 %)\n", + "camera_3_progress (00:00:51): 143 / 918 seconds (15.6 %)\n", + "camera_0_progress (00:00:51): 144 / 919 seconds (15.7 %)\n", + "camera_3_progress (00:00:52): 145 / 918 seconds (15.8 %)\n", + "camera_0_progress (00:00:52): 146 / 919 seconds (15.9 %)\n", + "camera_2_progress (00:00:52): 146 / 918 seconds (15.9 %)\n", + "camera_1_progress (00:00:52): 146 / 918 seconds (15.9 %)\n", + "camera_2_progress (00:00:53): 148 / 918 seconds (16.1 %)\n", + "camera_1_progress (00:00:53): 149 / 918 seconds (16.2 %)\n", + "camera_3_progress (00:00:53): 148 / 918 seconds (16.1 %)\n", + "camera_0_progress (00:00:53): 149 / 919 seconds (16.2 %)\n", + "camera_1_progress (00:00:54): 151 / 918 seconds (16.4 %)\n", + "camera_3_progress (00:00:54): 151 / 918 seconds (16.4 %)\n", + "camera_0_progress (00:00:54): 152 / 919 seconds (16.5 %)\n", + "camera_2_progress (00:00:54): 151 / 918 seconds (16.4 %)\n", + "camera_1_progress (00:00:55): 154 / 918 seconds (16.8 %)\n", + "camera_3_progress (00:00:55): 154 / 918 seconds (16.8 %)\n", + "camera_0_progress (00:00:55): 155 / 919 seconds (16.9 %)\n", + "camera_2_progress (00:00:55): 154 / 918 seconds (16.8 %)\n", + "camera_3_progress (00:00:56): 156 / 918 seconds (17.0 %)\n", + "camera_0_progress (00:00:56): 157 / 919 seconds (17.1 %)\n", + "camera_2_progress (00:00:56): 157 / 918 seconds (17.1 %)\n", + "camera_1_progress (00:00:56): 157 / 918 seconds (17.1 %)\n", + "camera_0_progress (00:00:57): 160 / 919 seconds (17.4 %)\n", + "camera_2_progress (00:00:57): 159 / 918 seconds (17.3 %)\n", + "camera_1_progress (00:00:57): 160 / 918 seconds (17.4 %)\n", + "camera_3_progress (00:00:57): 159 / 918 seconds (17.3 %)\n", + "camera_1_progress (00:00:58): 162 / 918 seconds (17.6 %)\n", + "camera_3_progress (00:00:58): 162 / 918 seconds (17.6 %)\n", + "camera_0_progress (00:00:58): 163 / 919 seconds (17.7 %)\n", + "camera_2_progress (00:00:58): 162 / 918 seconds (17.6 %)\n", + "camera_2_progress (00:00:59): 165 / 918 seconds (18.0 %)\n", + "camera_1_progress (00:00:59): 165 / 918 seconds (18.0 %)\n", + "camera_3_progress (00:00:59): 164 / 918 seconds (17.9 %)\n", + "camera_0_progress (00:00:59): 165 / 919 seconds (18.0 %)\n", + "camera_2_progress (00:01:00): 167 / 918 seconds (18.2 %)\n", + "camera_1_progress (00:01:00): 168 / 918 seconds (18.3 %)\n", + "camera_3_progress (00:01:00): 167 / 918 seconds (18.2 %)\n", + "camera_0_progress (00:01:00): 168 / 919 seconds (18.3 %)\n", + "camera_1_progress (00:01:01): 171 / 918 seconds (18.6 %)\n", + "camera_3_progress (00:01:01): 170 / 918 seconds (18.5 %)\n", + "camera_0_progress (00:01:01): 171 / 919 seconds (18.6 %)\n", + "camera_2_progress (00:01:01): 170 / 918 seconds (18.5 %)\n", + "camera_3_progress (00:01:02): 173 / 918 seconds (18.8 %)\n", + "camera_0_progress (00:01:02): 174 / 919 seconds (18.9 %)\n", + "camera_2_progress (00:01:02): 173 / 918 seconds (18.8 %)\n", + "camera_1_progress (00:01:02): 173 / 918 seconds (18.8 %)\n", + "camera_1_progress (00:01:03): 176 / 918 seconds (19.2 %)\n", + "camera_3_progress (00:01:03): 175 / 918 seconds (19.1 %)\n", + "camera_0_progress (00:01:03): 176 / 919 seconds (19.2 %)\n", + "camera_2_progress (00:01:03): 176 / 918 seconds (19.2 %)\n", + "camera_0_progress (00:01:04): 179 / 919 seconds (19.5 %)\n", + "camera_2_progress (00:01:04): 178 / 918 seconds (19.4 %)\n", + "camera_1_progress (00:01:04): 179 / 918 seconds (19.5 %)\n", + "camera_3_progress (00:01:04): 178 / 918 seconds (19.4 %)\n", + "camera_0_progress (00:01:05): 182 / 919 seconds (19.8 %)\n", + "camera_2_progress (00:01:05): 181 / 918 seconds (19.7 %)\n", + "camera_1_progress (00:01:05): 181 / 918 seconds (19.7 %)\n", + "camera_3_progress (00:01:05): 181 / 918 seconds (19.7 %)\n", + "camera_0_progress (00:01:06): 184 / 919 seconds (20.0 %)\n", + "camera_2_progress (00:01:06): 184 / 918 seconds (20.0 %)\n", + "camera_1_progress (00:01:06): 184 / 918 seconds (20.0 %)\n", + "camera_3_progress (00:01:06): 183 / 918 seconds (19.9 %)\n", + "camera_2_progress (00:01:07): 186 / 918 seconds (20.3 %)\n", + "camera_1_progress (00:01:07): 187 / 918 seconds (20.4 %)\n", + "camera_3_progress (00:01:07): 186 / 918 seconds (20.3 %)\n", + "camera_0_progress (00:01:07): 187 / 919 seconds (20.3 %)\n", + "camera_3_progress (00:01:08): 189 / 918 seconds (20.6 %)\n", + "camera_0_progress (00:01:08): 190 / 919 seconds (20.7 %)\n", + "camera_2_progress (00:01:08): 189 / 918 seconds (20.6 %)\n", + "camera_1_progress (00:01:08): 190 / 918 seconds (20.7 %)\n", + "camera_3_progress (00:01:09): 192 / 918 seconds (20.9 %)\n", + "camera_0_progress (00:01:09): 193 / 919 seconds (21.0 %)\n", + "camera_2_progress (00:01:09): 192 / 918 seconds (20.9 %)\n", + "camera_1_progress (00:01:09): 192 / 918 seconds (20.9 %)\n", + "camera_3_progress (00:01:10): 194 / 918 seconds (21.1 %)\n", + "camera_0_progress (00:01:10): 195 / 919 seconds (21.2 %)\n", + "camera_2_progress (00:01:10): 195 / 918 seconds (21.2 %)\n", + "camera_1_progress (00:01:10): 195 / 918 seconds (21.2 %)\n", + "camera_0_progress (00:01:11): 198 / 919 seconds (21.5 %)\n", + "camera_2_progress (00:01:11): 197 / 918 seconds (21.5 %)\n", + "camera_1_progress (00:01:11): 198 / 918 seconds (21.6 %)\n", + "camera_3_progress (00:01:11): 197 / 918 seconds (21.5 %)\n", + "camera_3_progress (00:01:12): 200 / 918 seconds (21.8 %)\n", + "camera_0_progress (00:01:12): 201 / 919 seconds (21.9 %)\n", + "camera_2_progress (00:01:12): 200 / 918 seconds (21.8 %)\n", + "camera_1_progress (00:01:12): 200 / 918 seconds (21.8 %)\n", + "camera_1_progress (00:01:13): 203 / 918 seconds (22.1 %)\n", + "camera_3_progress (00:01:13): 202 / 918 seconds (22.0 %)\n", + "camera_0_progress (00:01:13): 203 / 919 seconds (22.1 %)\n", + "camera_2_progress (00:01:13): 203 / 918 seconds (22.1 %)\n", + "camera_1_progress (00:01:14): 206 / 918 seconds (22.4 %)\n", + "camera_3_progress (00:01:14): 205 / 918 seconds (22.3 %)\n", + "camera_0_progress (00:01:14): 206 / 919 seconds (22.4 %)\n", + "camera_2_progress (00:01:14): 205 / 918 seconds (22.3 %)\n", + "camera_1_progress (00:01:15): 208 / 918 seconds (22.7 %)\n", + "camera_3_progress (00:01:15): 208 / 918 seconds (22.7 %)\n", + "camera_0_progress (00:01:15): 209 / 919 seconds (22.7 %)\n", + "camera_2_progress (00:01:15): 208 / 918 seconds (22.7 %)\n", + "camera_3_progress (00:01:16): 211 / 918 seconds (23.0 %)\n", + "camera_0_progress (00:01:16): 212 / 919 seconds (23.1 %)\n", + "camera_2_progress (00:01:16): 211 / 918 seconds (23.0 %)\n", + "camera_1_progress (00:01:16): 212 / 918 seconds (23.1 %)\n", + "camera_0_progress (00:01:17): 214 / 919 seconds (23.3 %)\n", + "camera_2_progress (00:01:17): 213 / 918 seconds (23.2 %)\n", + "camera_1_progress (00:01:17): 214 / 918 seconds (23.3 %)\n", + "camera_3_progress (00:01:17): 213 / 918 seconds (23.2 %)\n", + "camera_0_progress (00:01:18): 217 / 919 seconds (23.6 %)\n", + "camera_2_progress (00:01:18): 216 / 918 seconds (23.5 %)\n", + "camera_1_progress (00:01:18): 216 / 918 seconds (23.5 %)\n", + "camera_3_progress (00:01:18): 216 / 918 seconds (23.5 %)\n", + "camera_2_progress (00:01:19): 218 / 918 seconds (23.7 %)\n", + "camera_1_progress (00:01:19): 219 / 918 seconds (23.9 %)\n", + "camera_3_progress (00:01:19): 218 / 918 seconds (23.7 %)\n", + "camera_0_progress (00:01:19): 219 / 919 seconds (23.8 %)\n", + "camera_3_progress (00:01:20): 221 / 918 seconds (24.1 %)\n", + "camera_0_progress (00:01:20): 222 / 919 seconds (24.2 %)\n", + "camera_2_progress (00:01:20): 221 / 918 seconds (24.1 %)\n", + "camera_1_progress (00:01:20): 221 / 918 seconds (24.1 %)\n", + "camera_1_progress (00:01:21): 224 / 918 seconds (24.4 %)\n", + "camera_3_progress (00:01:21): 223 / 918 seconds (24.3 %)\n", + "camera_0_progress (00:01:21): 224 / 919 seconds (24.4 %)\n", + "camera_2_progress (00:01:21): 224 / 918 seconds (24.4 %)\n", + "camera_2_progress (00:01:22): 226 / 918 seconds (24.6 %)\n", + "camera_1_progress (00:01:22): 227 / 918 seconds (24.7 %)\n", + "camera_3_progress (00:01:22): 226 / 918 seconds (24.6 %)\n", + "camera_0_progress (00:01:22): 227 / 919 seconds (24.7 %)\n", + "camera_0_progress (00:01:23): 230 / 919 seconds (25.0 %)\n", + "camera_2_progress (00:01:23): 229 / 918 seconds (24.9 %)\n", + "camera_1_progress (00:01:23): 229 / 918 seconds (24.9 %)\n", + "camera_3_progress (00:01:23): 229 / 918 seconds (24.9 %)\n", + "camera_1_progress (00:01:24): 232 / 918 seconds (25.3 %)\n", + "camera_3_progress (00:01:24): 231 / 918 seconds (25.2 %)\n", + "camera_0_progress (00:01:24): 232 / 919 seconds (25.2 %)\n", + "camera_2_progress (00:01:24): 232 / 918 seconds (25.3 %)\n", + "camera_2_progress (00:01:25): 234 / 918 seconds (25.5 %)\n", + "camera_1_progress (00:01:25): 234 / 918 seconds (25.5 %)\n", + "camera_3_progress (00:01:25): 234 / 918 seconds (25.5 %)\n", + "camera_0_progress (00:01:25): 235 / 919 seconds (25.6 %)\n", + "camera_0_progress (00:01:26): 237 / 919 seconds (25.8 %)\n", + "camera_2_progress (00:01:26): 237 / 918 seconds (25.8 %)\n", + "camera_1_progress (00:01:26): 237 / 918 seconds (25.8 %)\n", + "camera_3_progress (00:01:26): 236 / 918 seconds (25.7 %)\n", + "camera_1_progress (00:01:27): 240 / 918 seconds (26.1 %)\n", + "camera_3_progress (00:01:27): 239 / 918 seconds (26.0 %)\n", + "camera_0_progress (00:01:27): 240 / 919 seconds (26.1 %)\n", + "camera_2_progress (00:01:27): 239 / 918 seconds (26.0 %)\n", + "camera_2_progress (00:01:28): 242 / 918 seconds (26.4 %)\n", + "camera_1_progress (00:01:28): 242 / 918 seconds (26.4 %)\n", + "camera_3_progress (00:01:28): 242 / 918 seconds (26.4 %)\n", + "camera_0_progress (00:01:28): 243 / 919 seconds (26.4 %)\n", + "camera_2_progress (00:01:29): 244 / 918 seconds (26.6 %)\n", + "camera_1_progress (00:01:29): 245 / 918 seconds (26.7 %)\n", + "camera_3_progress (00:01:29): 244 / 918 seconds (26.6 %)\n", + "camera_0_progress (00:01:29): 245 / 919 seconds (26.7 %)\n", + "camera_0_progress (00:01:30): 248 / 919 seconds (27.0 %)\n", + "camera_2_progress (00:01:30): 247 / 918 seconds (26.9 %)\n", + "camera_1_progress (00:01:30): 247 / 918 seconds (26.9 %)\n", + "camera_3_progress (00:01:30): 247 / 918 seconds (26.9 %)\n", + "camera_2_progress (00:01:31): 250 / 918 seconds (27.2 %)\n", + "camera_1_progress (00:01:31): 250 / 918 seconds (27.2 %)\n", + "camera_3_progress (00:01:31): 249 / 918 seconds (27.1 %)\n", + "camera_0_progress (00:01:31): 250 / 919 seconds (27.2 %)\n", + "camera_2_progress (00:01:32): 252 / 918 seconds (27.5 %)\n", + "camera_1_progress (00:01:32): 252 / 918 seconds (27.5 %)\n", + "camera_3_progress (00:01:32): 252 / 918 seconds (27.5 %)\n", + "camera_0_progress (00:01:32): 253 / 919 seconds (27.5 %)\n", + "camera_3_progress (00:01:33): 255 / 918 seconds (27.8 %)\n", + "camera_0_progress (00:01:33): 256 / 919 seconds (27.9 %)\n", + "camera_2_progress (00:01:33): 255 / 918 seconds (27.8 %)\n", + "camera_1_progress (00:01:33): 255 / 918 seconds (27.8 %)\n", + "camera_3_progress (00:01:34): 257 / 918 seconds (28.0 %)\n", + "camera_0_progress (00:01:34): 258 / 919 seconds (28.1 %)\n", + "camera_2_progress (00:01:34): 258 / 918 seconds (28.1 %)\n", + "camera_1_progress (00:01:34): 258 / 918 seconds (28.1 %)\n", + "camera_3_progress (00:01:35): 260 / 918 seconds (28.3 %)\n", + "camera_0_progress (00:01:35): 261 / 919 seconds (28.4 %)\n", + "camera_2_progress (00:01:35): 260 / 918 seconds (28.3 %)\n", + "camera_1_progress (00:01:35): 260 / 918 seconds (28.3 %)\n", + "camera_3_progress (00:01:36): 262 / 918 seconds (28.5 %)\n", + "camera_0_progress (00:01:36): 263 / 919 seconds (28.6 %)\n", + "camera_2_progress (00:01:36): 263 / 918 seconds (28.6 %)\n", + "camera_1_progress (00:01:36): 263 / 918 seconds (28.6 %)\n", + "camera_2_progress (00:01:37): 265 / 918 seconds (28.9 %)\n", + "camera_1_progress (00:01:37): 265 / 918 seconds (28.9 %)\n", + "camera_3_progress (00:01:37): 265 / 918 seconds (28.9 %)\n", + "camera_0_progress (00:01:37): 266 / 919 seconds (28.9 %)\n", + "camera_0_progress (00:01:38): 269 / 919 seconds (29.3 %)\n", + "camera_2_progress (00:01:38): 268 / 918 seconds (29.2 %)\n", + "camera_1_progress (00:01:38): 268 / 918 seconds (29.2 %)\n", + "camera_3_progress (00:01:38): 268 / 918 seconds (29.2 %)\n", + "camera_2_progress (00:01:39): 270 / 918 seconds (29.4 %)\n", + "camera_1_progress (00:01:39): 271 / 918 seconds (29.5 %)\n", + "camera_3_progress (00:01:39): 270 / 918 seconds (29.4 %)\n", + "camera_0_progress (00:01:39): 271 / 919 seconds (29.5 %)\n", + "camera_1_progress (00:01:40): 273 / 918 seconds (29.7 %)\n", + "camera_3_progress (00:01:40): 272 / 918 seconds (29.6 %)\n", + "camera_0_progress (00:01:40): 273 / 919 seconds (29.7 %)\n", + "camera_2_progress (00:01:40): 273 / 918 seconds (29.7 %)\n", + "camera_0_progress (00:01:41): 276 / 919 seconds (30.0 %)\n", + "camera_2_progress (00:01:41): 275 / 918 seconds (30.0 %)\n", + "camera_1_progress (00:01:41): 275 / 918 seconds (30.0 %)\n", + "camera_3_progress (00:01:41): 275 / 918 seconds (30.0 %)\n", + "camera_3_progress (00:01:42): 278 / 918 seconds (30.3 %)\n", + "camera_0_progress (00:01:42): 279 / 919 seconds (30.4 %)\n", + "camera_2_progress (00:01:42): 278 / 918 seconds (30.3 %)\n", + "camera_1_progress (00:01:42): 278 / 918 seconds (30.3 %)\n", + "camera_2_progress (00:01:43): 280 / 918 seconds (30.5 %)\n", + "camera_1_progress (00:01:43): 281 / 918 seconds (30.6 %)\n", + "camera_3_progress (00:01:43): 280 / 918 seconds (30.5 %)\n", + "camera_0_progress (00:01:43): 281 / 919 seconds (30.6 %)\n", + "camera_3_progress (00:01:44): 283 / 918 seconds (30.8 %)\n", + "camera_0_progress (00:01:44): 284 / 919 seconds (30.9 %)\n", + "camera_2_progress (00:01:44): 283 / 918 seconds (30.8 %)\n", + "camera_1_progress (00:01:44): 283 / 918 seconds (30.8 %)\n", + "camera_3_progress (00:01:45): 286 / 918 seconds (31.2 %)\n", + "camera_0_progress (00:01:45): 287 / 919 seconds (31.2 %)\n", + "camera_2_progress (00:01:45): 286 / 918 seconds (31.2 %)\n", + "camera_1_progress (00:01:45): 286 / 918 seconds (31.2 %)\n", + "camera_1_progress (00:01:46): 288 / 918 seconds (31.4 %)\n", + "camera_3_progress (00:01:46): 288 / 918 seconds (31.4 %)\n", + "camera_0_progress (00:01:46): 289 / 919 seconds (31.4 %)\n", + "camera_2_progress (00:01:46): 288 / 918 seconds (31.4 %)\n", + "camera_2_progress (00:01:47): 291 / 918 seconds (31.7 %)\n", + "camera_1_progress (00:01:47): 291 / 918 seconds (31.7 %)\n", + "camera_3_progress (00:01:47): 290 / 918 seconds (31.6 %)\n", + "camera_0_progress (00:01:47): 291 / 919 seconds (31.7 %)\n", + "camera_0_progress (00:01:48): 294 / 919 seconds (32.0 %)\n", + "camera_2_progress (00:01:48): 293 / 918 seconds (31.9 %)\n", + "camera_1_progress (00:01:48): 294 / 918 seconds (32.0 %)\n", + "camera_3_progress (00:01:48): 293 / 918 seconds (31.9 %)\n", + "camera_2_progress (00:01:49): 296 / 918 seconds (32.2 %)\n", + "camera_1_progress (00:01:49): 296 / 918 seconds (32.2 %)\n", + "camera_3_progress (00:01:49): 296 / 918 seconds (32.2 %)\n", + "camera_0_progress (00:01:49): 297 / 919 seconds (32.3 %)\n", + "camera_3_progress (00:01:50): 298 / 918 seconds (32.5 %)\n", + "camera_0_progress (00:01:50): 299 / 919 seconds (32.5 %)\n", + "camera_2_progress (00:01:50): 299 / 918 seconds (32.6 %)\n", + "camera_1_progress (00:01:50): 299 / 918 seconds (32.6 %)\n", + "camera_1_progress (00:01:51): 301 / 918 seconds (32.8 %)\n", + "camera_3_progress (00:01:51): 301 / 918 seconds (32.8 %)\n", + "camera_0_progress (00:01:51): 302 / 919 seconds (32.9 %)\n", + "camera_2_progress (00:01:51): 301 / 918 seconds (32.8 %)\n", + "camera_0_progress (00:01:52): 304 / 919 seconds (33.1 %)\n", + "camera_2_progress (00:01:52): 304 / 918 seconds (33.1 %)\n", + "camera_1_progress (00:01:52): 304 / 918 seconds (33.1 %)\n", + "camera_3_progress (00:01:52): 303 / 918 seconds (33.0 %)\n", + "camera_0_progress (00:01:53): 307 / 919 seconds (33.4 %)\n", + "camera_2_progress (00:01:53): 306 / 918 seconds (33.3 %)\n", + "camera_1_progress (00:01:53): 306 / 918 seconds (33.3 %)\n", + "camera_3_progress (00:01:53): 306 / 918 seconds (33.3 %)\n", + "camera_1_progress (00:01:54): 309 / 918 seconds (33.7 %)\n", + "camera_3_progress (00:01:54): 308 / 918 seconds (33.6 %)\n", + "camera_0_progress (00:01:54): 309 / 919 seconds (33.6 %)\n", + "camera_2_progress (00:01:54): 309 / 918 seconds (33.7 %)\n", + "camera_3_progress (00:01:55): 311 / 918 seconds (33.9 %)\n", + "camera_0_progress (00:01:55): 312 / 919 seconds (33.9 %)\n", + "camera_2_progress (00:01:55): 311 / 918 seconds (33.9 %)\n", + "camera_1_progress (00:01:55): 312 / 918 seconds (34.0 %)\n", + "camera_3_progress (00:01:56): 314 / 918 seconds (34.2 %)\n", + "camera_0_progress (00:01:56): 315 / 919 seconds (34.3 %)\n", + "camera_2_progress (00:01:56): 314 / 918 seconds (34.2 %)\n", + "camera_1_progress (00:01:56): 314 / 918 seconds (34.2 %)\n", + "camera_2_progress (00:01:57): 316 / 918 seconds (34.4 %)\n", + "camera_3_progress (00:01:57): 316 / 918 seconds (34.4 %)\n", + "camera_1_progress (00:01:57): 317 / 918 seconds (34.5 %)\n", + "camera_0_progress (00:01:57): 317 / 919 seconds (34.5 %)\n", + "camera_3_progress (00:01:58): 319 / 918 seconds (34.7 %)\n", + "camera_0_progress (00:01:58): 320 / 919 seconds (34.8 %)\n", + "camera_2_progress (00:01:58): 319 / 918 seconds (34.7 %)\n", + "camera_1_progress (00:01:58): 319 / 918 seconds (34.7 %)\n", + "camera_0_progress (00:01:59): 322 / 919 seconds (35.0 %)\n", + "camera_2_progress (00:01:59): 321 / 918 seconds (35.0 %)\n", + "camera_1_progress (00:01:59): 322 / 918 seconds (35.1 %)\n", + "camera_3_progress (00:01:59): 321 / 918 seconds (35.0 %)\n", + "camera_2_progress (00:02:00): 324 / 918 seconds (35.3 %)\n", + "camera_1_progress (00:02:00): 324 / 918 seconds (35.3 %)\n", + "camera_3_progress (00:02:00): 324 / 918 seconds (35.3 %)\n", + "camera_0_progress (00:02:00): 325 / 919 seconds (35.4 %)\n", + "camera_3_progress (00:02:01): 326 / 918 seconds (35.5 %)\n", + "camera_0_progress (00:02:01): 327 / 919 seconds (35.6 %)\n", + "camera_2_progress (00:02:01): 327 / 918 seconds (35.6 %)\n", + "camera_1_progress (00:02:01): 327 / 918 seconds (35.6 %)\n", + "camera_1_progress (00:02:02): 330 / 918 seconds (35.9 %)\n", + "camera_3_progress (00:02:02): 329 / 918 seconds (35.8 %)\n", + "camera_0_progress (00:02:02): 330 / 919 seconds (35.9 %)\n", + "camera_2_progress (00:02:02): 329 / 918 seconds (35.8 %)\n", + "camera_2_progress (00:02:03): 332 / 918 seconds (36.2 %)\n", + "camera_1_progress (00:02:03): 332 / 918 seconds (36.2 %)\n", + "camera_3_progress (00:02:03): 332 / 918 seconds (36.2 %)\n", + "camera_0_progress (00:02:03): 333 / 919 seconds (36.2 %)\n", + "camera_3_progress (00:02:04): 334 / 918 seconds (36.4 %)\n", + "camera_0_progress (00:02:04): 335 / 919 seconds (36.5 %)\n", + "camera_2_progress (00:02:04): 334 / 918 seconds (36.4 %)\n", + "camera_1_progress (00:02:04): 335 / 918 seconds (36.5 %)\n", + "camera_1_progress (00:02:05): 337 / 918 seconds (36.7 %)\n", + "camera_3_progress (00:02:05): 337 / 918 seconds (36.7 %)\n", + "camera_0_progress (00:02:05): 338 / 919 seconds (36.8 %)\n", + "camera_2_progress (00:02:05): 337 / 918 seconds (36.7 %)\n", + "camera_2_progress (00:02:06): 339 / 918 seconds (36.9 %)\n", + "camera_1_progress (00:02:06): 340 / 918 seconds (37.0 %)\n", + "camera_3_progress (00:02:06): 339 / 918 seconds (36.9 %)\n", + "camera_0_progress (00:02:06): 340 / 919 seconds (37.0 %)\n", + "camera_1_progress (00:02:07): 342 / 918 seconds (37.3 %)\n", + "camera_3_progress (00:02:07): 342 / 918 seconds (37.3 %)\n", + "camera_0_progress (00:02:07): 343 / 919 seconds (37.3 %)\n", + "camera_2_progress (00:02:07): 342 / 918 seconds (37.3 %)\n", + "camera_2_progress (00:02:08): 345 / 918 seconds (37.6 %)\n", + "camera_1_progress (00:02:08): 345 / 918 seconds (37.6 %)\n", + "camera_3_progress (00:02:08): 344 / 918 seconds (37.5 %)\n", + "camera_0_progress (00:02:08): 346 / 919 seconds (37.6 %)\n", + "camera_3_progress (00:02:09): 347 / 918 seconds (37.8 %)\n", + "camera_0_progress (00:02:09): 348 / 919 seconds (37.9 %)\n", + "camera_2_progress (00:02:09): 347 / 918 seconds (37.8 %)\n", + "camera_1_progress (00:02:09): 348 / 918 seconds (37.9 %)\n", + "camera_1_progress (00:02:10): 350 / 918 seconds (38.1 %)\n", + "camera_3_progress (00:02:10): 350 / 918 seconds (38.1 %)\n", + "camera_0_progress (00:02:10): 351 / 919 seconds (38.2 %)\n", + "camera_2_progress (00:02:10): 350 / 918 seconds (38.1 %)\n", + "camera_2_progress (00:02:11): 353 / 918 seconds (38.5 %)\n", + "camera_1_progress (00:02:11): 353 / 918 seconds (38.5 %)\n", + "camera_3_progress (00:02:11): 352 / 918 seconds (38.3 %)\n", + "camera_0_progress (00:02:11): 353 / 919 seconds (38.4 %)\n", + "camera_3_progress (00:02:12): 355 / 918 seconds (38.7 %)\n", + "camera_0_progress (00:02:12): 356 / 919 seconds (38.7 %)\n", + "camera_2_progress (00:02:12): 355 / 918 seconds (38.7 %)\n", + "camera_1_progress (00:02:12): 356 / 918 seconds (38.8 %)\n", + "camera_0_progress (00:02:13): 358 / 919 seconds (39.0 %)\n", + "camera_2_progress (00:02:13): 358 / 918 seconds (39.0 %)\n", + "camera_1_progress (00:02:13): 358 / 918 seconds (39.0 %)\n", + "camera_3_progress (00:02:13): 357 / 918 seconds (38.9 %)\n", + "camera_3_progress (00:02:14): 360 / 918 seconds (39.2 %)\n", + "camera_0_progress (00:02:14): 361 / 919 seconds (39.3 %)\n", + "camera_2_progress (00:02:14): 360 / 918 seconds (39.2 %)\n", + "camera_1_progress (00:02:14): 361 / 918 seconds (39.3 %)\n", + "camera_3_progress (00:02:15): 362 / 918 seconds (39.4 %)\n", + "camera_0_progress (00:02:15): 363 / 919 seconds (39.5 %)\n", + "camera_2_progress (00:02:15): 363 / 918 seconds (39.5 %)\n", + "camera_1_progress (00:02:15): 363 / 918 seconds (39.5 %)\n", + "camera_1_progress (00:02:16): 366 / 918 seconds (39.9 %)\n", + "camera_3_progress (00:02:16): 365 / 918 seconds (39.8 %)\n", + "camera_0_progress (00:02:16): 366 / 919 seconds (39.8 %)\n", + "camera_2_progress (00:02:16): 365 / 918 seconds (39.8 %)\n", + "camera_2_progress (00:02:17): 368 / 918 seconds (40.1 %)\n", + "camera_1_progress (00:02:17): 368 / 918 seconds (40.1 %)\n", + "camera_3_progress (00:02:17): 368 / 918 seconds (40.1 %)\n", + "camera_0_progress (00:02:17): 369 / 919 seconds (40.2 %)\n", + "camera_2_progress (00:02:18): 371 / 918 seconds (40.4 %)\n", + "camera_1_progress (00:02:18): 371 / 918 seconds (40.4 %)\n", + "camera_3_progress (00:02:18): 370 / 918 seconds (40.3 %)\n", + "camera_0_progress (00:02:18): 371 / 919 seconds (40.4 %)\n", + "camera_3_progress (00:02:19): 373 / 918 seconds (40.6 %)\n", + "camera_0_progress (00:02:19): 374 / 919 seconds (40.7 %)\n", + "camera_2_progress (00:02:19): 373 / 918 seconds (40.6 %)\n", + "camera_1_progress (00:02:19): 373 / 918 seconds (40.6 %)\n", + "camera_1_progress (00:02:20): 376 / 918 seconds (41.0 %)\n", + "camera_3_progress (00:02:20): 375 / 918 seconds (40.8 %)\n", + "camera_0_progress (00:02:20): 376 / 919 seconds (40.9 %)\n", + "camera_2_progress (00:02:20): 375 / 918 seconds (40.8 %)\n", + "camera_2_progress (00:02:21): 378 / 918 seconds (41.2 %)\n", + "camera_1_progress (00:02:21): 378 / 918 seconds (41.2 %)\n", + "camera_3_progress (00:02:21): 378 / 918 seconds (41.2 %)\n", + "camera_0_progress (00:02:21): 379 / 919 seconds (41.2 %)\n", + "camera_3_progress (00:02:22): 380 / 918 seconds (41.4 %)\n", + "camera_0_progress (00:02:22): 381 / 919 seconds (41.5 %)\n", + "camera_2_progress (00:02:22): 381 / 918 seconds (41.5 %)\n", + "camera_1_progress (00:02:22): 381 / 918 seconds (41.5 %)\n", + "camera_1_progress (00:02:23): 384 / 918 seconds (41.8 %)\n", + "camera_3_progress (00:02:23): 383 / 918 seconds (41.7 %)\n", + "camera_0_progress (00:02:23): 384 / 919 seconds (41.8 %)\n", + "camera_2_progress (00:02:23): 383 / 918 seconds (41.7 %)\n", + "camera_3_progress (00:02:24): 385 / 918 seconds (41.9 %)\n", + "camera_0_progress (00:02:24): 386 / 919 seconds (42.0 %)\n", + "camera_2_progress (00:02:24): 386 / 918 seconds (42.0 %)\n", + "camera_1_progress (00:02:24): 386 / 918 seconds (42.0 %)\n", + "camera_2_progress (00:02:25): 388 / 918 seconds (42.3 %)\n", + "camera_1_progress (00:02:25): 389 / 918 seconds (42.4 %)\n", + "camera_3_progress (00:02:25): 388 / 918 seconds (42.3 %)\n", + "camera_0_progress (00:02:25): 389 / 919 seconds (42.3 %)\n", + "camera_2_progress (00:02:26): 391 / 918 seconds (42.6 %)\n", + "camera_1_progress (00:02:26): 391 / 918 seconds (42.6 %)\n", + "camera_3_progress (00:02:26): 391 / 918 seconds (42.6 %)\n", + "camera_0_progress (00:02:26): 392 / 919 seconds (42.7 %)\n", + "camera_0_progress (00:02:27): 394 / 919 seconds (42.9 %)\n", + "camera_2_progress (00:02:27): 393 / 918 seconds (42.8 %)\n", + "camera_1_progress (00:02:27): 394 / 918 seconds (42.9 %)\n", + "camera_3_progress (00:02:27): 393 / 918 seconds (42.8 %)\n", + "camera_0_progress (00:02:28): 397 / 919 seconds (43.2 %)\n", + "camera_2_progress (00:02:28): 396 / 918 seconds (43.1 %)\n", + "camera_1_progress (00:02:28): 396 / 918 seconds (43.1 %)\n", + "camera_3_progress (00:02:28): 396 / 918 seconds (43.1 %)\n", + "camera_1_progress (00:02:29): 399 / 918 seconds (43.5 %)\n", + "camera_3_progress (00:02:29): 398 / 918 seconds (43.4 %)\n", + "camera_0_progress (00:02:29): 400 / 919 seconds (43.5 %)\n", + "camera_2_progress (00:02:29): 399 / 918 seconds (43.5 %)\n", + "camera_1_progress (00:02:30): 402 / 918 seconds (43.8 %)\n", + "camera_3_progress (00:02:30): 401 / 918 seconds (43.7 %)\n", + "camera_0_progress (00:02:30): 402 / 919 seconds (43.7 %)\n", + "camera_2_progress (00:02:30): 401 / 918 seconds (43.7 %)\n", + "camera_1_progress (00:02:31): 404 / 918 seconds (44.0 %)\n", + "camera_3_progress (00:02:31): 404 / 918 seconds (44.0 %)\n", + "camera_0_progress (00:02:31): 405 / 919 seconds (44.1 %)\n", + "camera_2_progress (00:02:31): 404 / 918 seconds (44.0 %)\n", + "camera_3_progress (00:02:32): 406 / 918 seconds (44.2 %)\n", + "camera_0_progress (00:02:32): 407 / 919 seconds (44.3 %)\n", + "camera_2_progress (00:02:32): 407 / 918 seconds (44.3 %)\n", + "camera_1_progress (00:02:32): 407 / 918 seconds (44.3 %)\n", + "camera_0_progress (00:02:33): 410 / 919 seconds (44.6 %)\n", + "camera_2_progress (00:02:33): 409 / 918 seconds (44.6 %)\n", + "camera_1_progress (00:02:33): 410 / 918 seconds (44.7 %)\n", + "camera_3_progress (00:02:33): 409 / 918 seconds (44.6 %)\n", + "camera_3_progress (00:02:34): 411 / 918 seconds (44.8 %)\n", + "camera_0_progress (00:02:34): 412 / 919 seconds (44.8 %)\n", + "camera_2_progress (00:02:34): 412 / 918 seconds (44.9 %)\n", + "camera_1_progress (00:02:34): 412 / 918 seconds (44.9 %)\n", + "camera_2_progress (00:02:35): 414 / 918 seconds (45.1 %)\n", + "camera_1_progress (00:02:35): 415 / 918 seconds (45.2 %)\n", + "camera_3_progress (00:02:35): 414 / 918 seconds (45.1 %)\n", + "camera_0_progress (00:02:35): 415 / 919 seconds (45.2 %)\n", + "camera_1_progress (00:02:36): 417 / 918 seconds (45.4 %)\n", + "camera_3_progress (00:02:36): 416 / 918 seconds (45.3 %)\n", + "camera_0_progress (00:02:36): 418 / 919 seconds (45.5 %)\n", + "camera_2_progress (00:02:36): 417 / 918 seconds (45.4 %)\n", + "camera_3_progress (00:02:37): 419 / 918 seconds (45.6 %)\n", + "camera_0_progress (00:02:37): 420 / 919 seconds (45.7 %)\n", + "camera_2_progress (00:02:37): 419 / 918 seconds (45.6 %)\n", + "camera_1_progress (00:02:37): 420 / 918 seconds (45.8 %)\n", + "camera_0_progress (00:02:38): 423 / 919 seconds (46.0 %)\n", + "camera_2_progress (00:02:38): 422 / 918 seconds (46.0 %)\n", + "camera_1_progress (00:02:38): 422 / 918 seconds (46.0 %)\n", + "camera_3_progress (00:02:38): 422 / 918 seconds (46.0 %)\n", + "camera_1_progress (00:02:39): 425 / 918 seconds (46.3 %)\n", + "camera_3_progress (00:02:39): 424 / 918 seconds (46.2 %)\n", + "camera_0_progress (00:02:39): 425 / 919 seconds (46.2 %)\n", + "camera_2_progress (00:02:39): 425 / 918 seconds (46.3 %)\n", + "camera_1_progress (00:02:40): 427 / 918 seconds (46.5 %)\n", + "camera_3_progress (00:02:40): 427 / 918 seconds (46.5 %)\n", + "camera_0_progress (00:02:40): 428 / 919 seconds (46.6 %)\n", + "camera_2_progress (00:02:40): 427 / 918 seconds (46.5 %)\n", + "camera_0_progress (00:02:41): 430 / 919 seconds (46.8 %)\n", + "camera_2_progress (00:02:41): 430 / 918 seconds (46.8 %)\n", + "camera_1_progress (00:02:41): 430 / 918 seconds (46.8 %)\n", + "camera_3_progress (00:02:41): 429 / 918 seconds (46.7 %)\n", + "camera_2_progress (00:02:42): 432 / 918 seconds (47.1 %)\n", + "camera_1_progress (00:02:42): 432 / 918 seconds (47.1 %)\n", + "camera_3_progress (00:02:42): 432 / 918 seconds (47.1 %)\n", + "camera_0_progress (00:02:42): 433 / 919 seconds (47.1 %)\n", + "camera_1_progress (00:02:43): 435 / 918 seconds (47.4 %)\n", + "camera_3_progress (00:02:43): 434 / 918 seconds (47.3 %)\n", + "camera_0_progress (00:02:43): 435 / 919 seconds (47.3 %)\n", + "camera_2_progress (00:02:43): 435 / 918 seconds (47.4 %)\n", + "camera_3_progress (00:02:44): 437 / 918 seconds (47.6 %)\n", + "camera_0_progress (00:02:44): 438 / 919 seconds (47.7 %)\n", + "camera_2_progress (00:02:44): 437 / 918 seconds (47.6 %)\n", + "camera_1_progress (00:02:44): 438 / 918 seconds (47.7 %)\n", + "camera_1_progress (00:02:45): 440 / 918 seconds (47.9 %)\n", + "camera_3_progress (00:02:45): 440 / 918 seconds (47.9 %)\n", + "camera_0_progress (00:02:45): 441 / 919 seconds (48.0 %)\n", + "camera_2_progress (00:02:45): 440 / 918 seconds (47.9 %)\n", + "camera_0_progress (00:02:46): 443 / 919 seconds (48.2 %)\n", + "camera_2_progress (00:02:46): 443 / 918 seconds (48.3 %)\n", + "camera_1_progress (00:02:46): 443 / 918 seconds (48.3 %)\n", + "camera_3_progress (00:02:46): 442 / 918 seconds (48.1 %)\n", + "camera_0_progress (00:02:47): 446 / 919 seconds (48.5 %)\n", + "camera_2_progress (00:02:47): 445 / 918 seconds (48.5 %)\n", + "camera_1_progress (00:02:47): 445 / 918 seconds (48.5 %)\n", + "camera_3_progress (00:02:47): 445 / 918 seconds (48.5 %)\n", + "camera_1_progress (00:02:48): 448 / 918 seconds (48.8 %)\n", + "camera_3_progress (00:02:48): 447 / 918 seconds (48.7 %)\n", + "camera_0_progress (00:02:48): 448 / 919 seconds (48.7 %)\n", + "camera_2_progress (00:02:48): 448 / 918 seconds (48.8 %)\n", + "camera_3_progress (00:02:49): 450 / 918 seconds (49.0 %)\n", + "camera_0_progress (00:02:49): 451 / 919 seconds (49.1 %)\n", + "camera_2_progress (00:02:49): 450 / 918 seconds (49.0 %)\n", + "camera_1_progress (00:02:49): 451 / 918 seconds (49.1 %)\n", + "camera_2_progress (00:02:50): 453 / 918 seconds (49.3 %)\n", + "camera_1_progress (00:02:50): 453 / 918 seconds (49.3 %)\n", + "camera_3_progress (00:02:50): 453 / 918 seconds (49.3 %)\n", + "camera_0_progress (00:02:50): 454 / 919 seconds (49.4 %)\n", + "camera_1_progress (00:02:51): 456 / 918 seconds (49.7 %)\n", + "camera_3_progress (00:02:51): 455 / 918 seconds (49.6 %)\n", + "camera_0_progress (00:02:51): 456 / 919 seconds (49.6 %)\n", + "camera_2_progress (00:02:51): 456 / 918 seconds (49.7 %)\n", + "camera_2_progress (00:02:52): 458 / 918 seconds (49.9 %)\n", + "camera_1_progress (00:02:52): 458 / 918 seconds (49.9 %)\n", + "camera_3_progress (00:02:52): 458 / 918 seconds (49.9 %)\n", + "camera_0_progress (00:02:52): 459 / 919 seconds (49.9 %)\n", + "camera_3_progress (00:02:53): 460 / 918 seconds (50.1 %)\n", + "camera_0_progress (00:02:53): 461 / 919 seconds (50.2 %)\n", + "camera_2_progress (00:02:53): 461 / 918 seconds (50.2 %)\n", + "camera_1_progress (00:02:53): 461 / 918 seconds (50.2 %)\n", + "camera_2_progress (00:02:54): 463 / 918 seconds (50.4 %)\n", + "camera_1_progress (00:02:54): 464 / 918 seconds (50.5 %)\n", + "camera_3_progress (00:02:54): 463 / 918 seconds (50.4 %)\n", + "camera_0_progress (00:02:54): 464 / 919 seconds (50.5 %)\n", + "camera_3_progress (00:02:55): 466 / 918 seconds (50.8 %)\n", + "camera_0_progress (00:02:55): 467 / 919 seconds (50.8 %)\n", + "camera_2_progress (00:02:55): 466 / 918 seconds (50.8 %)\n", + "camera_1_progress (00:02:55): 466 / 918 seconds (50.8 %)\n", + "camera_0_progress (00:02:56): 469 / 919 seconds (51.0 %)\n", + "camera_2_progress (00:02:56): 468 / 918 seconds (51.0 %)\n", + "camera_1_progress (00:02:56): 469 / 918 seconds (51.1 %)\n", + "camera_3_progress (00:02:56): 468 / 918 seconds (51.0 %)\n", + "camera_2_progress (00:02:57): 471 / 918 seconds (51.3 %)\n", + "camera_1_progress (00:02:57): 471 / 918 seconds (51.3 %)\n", + "camera_3_progress (00:02:57): 471 / 918 seconds (51.3 %)\n", + "camera_0_progress (00:02:57): 472 / 919 seconds (51.4 %)\n", + "camera_3_progress (00:02:58): 473 / 918 seconds (51.5 %)\n", + "camera_0_progress (00:02:58): 474 / 919 seconds (51.6 %)\n", + "camera_2_progress (00:02:58): 474 / 918 seconds (51.6 %)\n", + "camera_1_progress (00:02:58): 474 / 918 seconds (51.6 %)\n", + "camera_1_progress (00:02:59): 476 / 918 seconds (51.9 %)\n", + "camera_3_progress (00:02:59): 476 / 918 seconds (51.9 %)\n", + "camera_0_progress (00:02:59): 477 / 919 seconds (51.9 %)\n", + "camera_2_progress (00:02:59): 476 / 918 seconds (51.9 %)\n", + "camera_2_progress (00:03:00): 479 / 918 seconds (52.2 %)\n", + "camera_1_progress (00:03:00): 479 / 918 seconds (52.2 %)\n", + "camera_3_progress (00:03:00): 478 / 918 seconds (52.1 %)\n", + "camera_0_progress (00:03:00): 479 / 919 seconds (52.1 %)\n", + "camera_3_progress (00:03:01): 481 / 918 seconds (52.4 %)\n", + "camera_0_progress (00:03:01): 482 / 919 seconds (52.4 %)\n", + "camera_2_progress (00:03:01): 482 / 918 seconds (52.5 %)\n", + "camera_1_progress (00:03:01): 482 / 918 seconds (52.5 %)\n", + "camera_2_progress (00:03:02): 484 / 918 seconds (52.7 %)\n", + "camera_1_progress (00:03:02): 484 / 918 seconds (52.7 %)\n", + "camera_3_progress (00:03:02): 484 / 918 seconds (52.7 %)\n", + "camera_0_progress (00:03:02): 485 / 919 seconds (52.8 %)\n", + "camera_2_progress (00:03:03): 487 / 918 seconds (53.1 %)\n", + "camera_1_progress (00:03:03): 487 / 918 seconds (53.1 %)\n", + "camera_3_progress (00:03:03): 486 / 918 seconds (52.9 %)\n", + "camera_0_progress (00:03:03): 487 / 919 seconds (53.0 %)\n", + "camera_2_progress (00:03:04): 489 / 918 seconds (53.3 %)\n", + "camera_1_progress (00:03:04): 489 / 918 seconds (53.3 %)\n", + "camera_3_progress (00:03:04): 489 / 918 seconds (53.3 %)\n", + "camera_0_progress (00:03:04): 490 / 919 seconds (53.3 %)\n", + "camera_3_progress (00:03:05): 491 / 918 seconds (53.5 %)\n", + "camera_0_progress (00:03:05): 492 / 919 seconds (53.5 %)\n", + "camera_2_progress (00:03:05): 492 / 918 seconds (53.6 %)\n", + "camera_1_progress (00:03:05): 492 / 918 seconds (53.6 %)\n", + "camera_0_progress (00:03:06): 495 / 919 seconds (53.9 %)\n", + "camera_2_progress (00:03:06): 494 / 918 seconds (53.8 %)\n", + "camera_1_progress (00:03:06): 494 / 918 seconds (53.8 %)\n", + "camera_3_progress (00:03:06): 494 / 918 seconds (53.8 %)\n", + "camera_0_progress (00:03:07): 497 / 919 seconds (54.1 %)\n", + "camera_2_progress (00:03:07): 497 / 918 seconds (54.1 %)\n", + "camera_1_progress (00:03:07): 497 / 918 seconds (54.1 %)\n", + "camera_3_progress (00:03:07): 496 / 918 seconds (54.0 %)\n", + "camera_3_progress (00:03:08): 499 / 918 seconds (54.4 %)\n", + "camera_1_progress (00:03:08): 500 / 918 seconds (54.5 %)\n", + "camera_0_progress (00:03:08): 500 / 919 seconds (54.4 %)\n", + "camera_2_progress (00:03:08): 499 / 918 seconds (54.4 %)\n", + "camera_2_progress (00:03:09): 502 / 918 seconds (54.7 %)\n", + "camera_1_progress (00:03:09): 502 / 918 seconds (54.7 %)\n", + "camera_3_progress (00:03:09): 501 / 918 seconds (54.6 %)\n", + "camera_0_progress (00:03:09): 502 / 919 seconds (54.6 %)\n", + "camera_3_progress (00:03:10): 504 / 918 seconds (54.9 %)\n", + "camera_0_progress (00:03:10): 505 / 919 seconds (55.0 %)\n", + "camera_2_progress (00:03:10): 504 / 918 seconds (54.9 %)\n", + "camera_1_progress (00:03:10): 505 / 918 seconds (55.0 %)\n", + "camera_0_progress (00:03:11): 507 / 919 seconds (55.2 %)\n", + "camera_2_progress (00:03:11): 507 / 918 seconds (55.2 %)\n", + "camera_1_progress (00:03:11): 507 / 918 seconds (55.2 %)\n", + "camera_3_progress (00:03:11): 506 / 918 seconds (55.1 %)\n", + "camera_1_progress (00:03:12): 510 / 918 seconds (55.6 %)\n", + "camera_3_progress (00:03:12): 509 / 918 seconds (55.4 %)\n", + "camera_0_progress (00:03:12): 510 / 919 seconds (55.5 %)\n", + "camera_2_progress (00:03:12): 509 / 918 seconds (55.4 %)\n", + "camera_0_progress (00:03:13): 513 / 919 seconds (55.8 %)\n", + "camera_2_progress (00:03:13): 512 / 918 seconds (55.8 %)\n", + "camera_1_progress (00:03:13): 512 / 918 seconds (55.8 %)\n", + "camera_3_progress (00:03:13): 512 / 918 seconds (55.8 %)\n", + "camera_2_progress (00:03:14): 514 / 918 seconds (56.0 %)\n", + "camera_1_progress (00:03:14): 515 / 918 seconds (56.1 %)\n", + "camera_3_progress (00:03:14): 514 / 918 seconds (56.0 %)\n", + "camera_0_progress (00:03:14): 515 / 919 seconds (56.0 %)\n", + "camera_1_progress (00:03:15): 517 / 918 seconds (56.3 %)\n", + "camera_2_progress (00:03:15): 517 / 918 seconds (56.3 %)\n", + "camera_3_progress (00:03:15): 517 / 918 seconds (56.3 %)\n", + "camera_0_progress (00:03:15): 518 / 919 seconds (56.4 %)\n", + "camera_0_progress (00:03:16): 520 / 919 seconds (56.6 %)\n", + "camera_2_progress (00:03:16): 520 / 918 seconds (56.6 %)\n", + "camera_1_progress (00:03:16): 520 / 918 seconds (56.6 %)\n", + "camera_3_progress (00:03:16): 519 / 918 seconds (56.5 %)\n", + "camera_3_progress (00:03:17): 522 / 918 seconds (56.9 %)\n", + "camera_0_progress (00:03:17): 523 / 919 seconds (56.9 %)\n", + "camera_2_progress (00:03:17): 522 / 918 seconds (56.9 %)\n", + "camera_1_progress (00:03:17): 523 / 918 seconds (57.0 %)\n", + "camera_3_progress (00:03:18): 524 / 918 seconds (57.1 %)\n", + "camera_0_progress (00:03:18): 525 / 919 seconds (57.1 %)\n", + "camera_2_progress (00:03:18): 525 / 918 seconds (57.2 %)\n", + "camera_1_progress (00:03:18): 525 / 918 seconds (57.2 %)\n", + "camera_0_progress (00:03:19): 528 / 919 seconds (57.5 %)\n", + "camera_2_progress (00:03:19): 527 / 918 seconds (57.4 %)\n", + "camera_1_progress (00:03:19): 527 / 918 seconds (57.4 %)\n", + "camera_3_progress (00:03:19): 527 / 918 seconds (57.4 %)\n", + "camera_3_progress (00:03:20): 529 / 918 seconds (57.6 %)\n", + "camera_0_progress (00:03:20): 530 / 919 seconds (57.7 %)\n", + "camera_2_progress (00:03:20): 530 / 918 seconds (57.7 %)\n", + "camera_1_progress (00:03:20): 530 / 918 seconds (57.7 %)\n", + "camera_2_progress (00:03:21): 532 / 918 seconds (58.0 %)\n", + "camera_1_progress (00:03:21): 532 / 918 seconds (58.0 %)\n", + "camera_3_progress (00:03:21): 532 / 918 seconds (58.0 %)\n", + "camera_0_progress (00:03:21): 533 / 919 seconds (58.0 %)\n", + "camera_0_progress (00:03:22): 535 / 919 seconds (58.2 %)\n", + "camera_2_progress (00:03:22): 535 / 918 seconds (58.3 %)\n", + "camera_1_progress (00:03:22): 535 / 918 seconds (58.3 %)\n", + "camera_3_progress (00:03:22): 534 / 918 seconds (58.2 %)\n", + "camera_1_progress (00:03:23): 538 / 918 seconds (58.6 %)\n", + "camera_3_progress (00:03:23): 537 / 918 seconds (58.5 %)\n", + "camera_0_progress (00:03:23): 538 / 919 seconds (58.5 %)\n", + "camera_2_progress (00:03:23): 537 / 918 seconds (58.5 %)\n", + "camera_1_progress (00:03:24): 540 / 918 seconds (58.8 %)\n", + "camera_3_progress (00:03:24): 540 / 918 seconds (58.8 %)\n", + "camera_0_progress (00:03:24): 541 / 919 seconds (58.9 %)\n", + "camera_2_progress (00:03:24): 540 / 918 seconds (58.8 %)\n", + "camera_0_progress (00:03:25): 543 / 919 seconds (59.1 %)\n", + "camera_2_progress (00:03:25): 542 / 918 seconds (59.0 %)\n", + "camera_1_progress (00:03:25): 543 / 918 seconds (59.2 %)\n", + "camera_3_progress (00:03:25): 542 / 918 seconds (59.0 %)\n", + "camera_0_progress (00:03:26): 545 / 919 seconds (59.3 %)\n", + "camera_2_progress (00:03:26): 545 / 918 seconds (59.4 %)\n", + "camera_1_progress (00:03:26): 545 / 918 seconds (59.4 %)\n", + "camera_3_progress (00:03:26): 544 / 918 seconds (59.3 %)\n", + "camera_1_progress (00:03:27): 548 / 918 seconds (59.7 %)\n", + "camera_3_progress (00:03:27): 547 / 918 seconds (59.6 %)\n", + "camera_0_progress (00:03:27): 548 / 919 seconds (59.6 %)\n", + "camera_2_progress (00:03:27): 547 / 918 seconds (59.6 %)\n", + "camera_2_progress (00:03:28): 550 / 918 seconds (59.9 %)\n", + "camera_1_progress (00:03:28): 550 / 918 seconds (59.9 %)\n", + "camera_3_progress (00:03:28): 549 / 918 seconds (59.8 %)\n", + "camera_0_progress (00:03:28): 551 / 919 seconds (60.0 %)\n", + "camera_3_progress (00:03:29): 552 / 918 seconds (60.1 %)\n", + "camera_0_progress (00:03:29): 553 / 919 seconds (60.2 %)\n", + "camera_2_progress (00:03:29): 552 / 918 seconds (60.1 %)\n", + "camera_1_progress (00:03:29): 553 / 918 seconds (60.2 %)\n", + "camera_1_progress (00:03:30): 555 / 918 seconds (60.5 %)\n", + "camera_3_progress (00:03:30): 554 / 918 seconds (60.3 %)\n", + "camera_0_progress (00:03:30): 555 / 919 seconds (60.4 %)\n", + "camera_2_progress (00:03:30): 555 / 918 seconds (60.5 %)\n", + "camera_2_progress (00:03:31): 557 / 918 seconds (60.7 %)\n", + "camera_1_progress (00:03:31): 557 / 918 seconds (60.7 %)\n", + "camera_3_progress (00:03:31): 557 / 918 seconds (60.7 %)\n", + "camera_0_progress (00:03:31): 558 / 919 seconds (60.7 %)\n", + "camera_0_progress (00:03:32): 560 / 919 seconds (60.9 %)\n", + "camera_2_progress (00:03:32): 560 / 918 seconds (61.0 %)\n", + "camera_1_progress (00:03:32): 560 / 918 seconds (61.0 %)\n", + "camera_3_progress (00:03:32): 559 / 918 seconds (60.9 %)\n", + "camera_2_progress (00:03:33): 562 / 918 seconds (61.2 %)\n", + "camera_1_progress (00:03:33): 562 / 918 seconds (61.2 %)\n", + "camera_3_progress (00:03:33): 562 / 918 seconds (61.2 %)\n", + "camera_0_progress (00:03:33): 563 / 919 seconds (61.3 %)\n", + "camera_1_progress (00:03:34): 565 / 918 seconds (61.5 %)\n", + "camera_3_progress (00:03:34): 564 / 918 seconds (61.4 %)\n", + "camera_0_progress (00:03:34): 565 / 919 seconds (61.5 %)\n", + "camera_2_progress (00:03:34): 565 / 918 seconds (61.5 %)\n", + "camera_0_progress (00:03:35): 568 / 919 seconds (61.8 %)\n", + "camera_2_progress (00:03:35): 567 / 918 seconds (61.8 %)\n", + "camera_1_progress (00:03:35): 567 / 918 seconds (61.8 %)\n", + "camera_3_progress (00:03:35): 567 / 918 seconds (61.8 %)\n", + "camera_1_progress (00:03:36): 570 / 918 seconds (62.1 %)\n", + "camera_3_progress (00:03:36): 569 / 918 seconds (62.0 %)\n", + "camera_0_progress (00:03:36): 570 / 919 seconds (62.0 %)\n", + "camera_2_progress (00:03:36): 569 / 918 seconds (62.0 %)\n", + "camera_0_progress (00:03:37): 572 / 919 seconds (62.2 %)\n", + "camera_2_progress (00:03:37): 572 / 918 seconds (62.3 %)\n", + "camera_1_progress (00:03:37): 572 / 918 seconds (62.3 %)\n", + "camera_3_progress (00:03:37): 571 / 918 seconds (62.2 %)\n", + "camera_2_progress (00:03:38): 574 / 918 seconds (62.5 %)\n", + "camera_1_progress (00:03:38): 574 / 918 seconds (62.5 %)\n", + "camera_3_progress (00:03:38): 574 / 918 seconds (62.5 %)\n", + "camera_0_progress (00:03:38): 575 / 919 seconds (62.6 %)\n", + "camera_0_progress (00:03:39): 578 / 919 seconds (62.9 %)\n", + "camera_2_progress (00:03:39): 577 / 918 seconds (62.9 %)\n", + "camera_1_progress (00:03:39): 577 / 918 seconds (62.9 %)\n", + "camera_3_progress (00:03:39): 577 / 918 seconds (62.9 %)\n", + "camera_1_progress (00:03:40): 579 / 918 seconds (63.1 %)\n", + "camera_3_progress (00:03:40): 579 / 918 seconds (63.1 %)\n", + "camera_0_progress (00:03:40): 580 / 919 seconds (63.1 %)\n", + "camera_2_progress (00:03:40): 579 / 918 seconds (63.1 %)\n", + "camera_3_progress (00:03:41): 581 / 918 seconds (63.3 %)\n", + "camera_0_progress (00:03:41): 582 / 919 seconds (63.3 %)\n", + "camera_2_progress (00:03:41): 582 / 918 seconds (63.4 %)\n", + "camera_1_progress (00:03:41): 582 / 918 seconds (63.4 %)\n", + "camera_2_progress (00:03:42): 584 / 918 seconds (63.6 %)\n", + "camera_1_progress (00:03:42): 584 / 918 seconds (63.6 %)\n", + "camera_3_progress (00:03:42): 584 / 918 seconds (63.6 %)\n", + "camera_0_progress (00:03:42): 585 / 919 seconds (63.7 %)\n", + "camera_0_progress (00:03:43): 587 / 919 seconds (63.9 %)\n", + "camera_2_progress (00:03:43): 586 / 918 seconds (63.8 %)\n", + "camera_1_progress (00:03:43): 587 / 918 seconds (63.9 %)\n", + "camera_3_progress (00:03:43): 586 / 918 seconds (63.8 %)\n", + "camera_3_progress (00:03:44): 589 / 918 seconds (64.2 %)\n", + "camera_0_progress (00:03:44): 590 / 919 seconds (64.2 %)\n", + "camera_2_progress (00:03:44): 589 / 918 seconds (64.2 %)\n", + "camera_1_progress (00:03:44): 590 / 918 seconds (64.3 %)\n", + "camera_1_progress (00:03:45): 592 / 918 seconds (64.5 %)\n", + "camera_3_progress (00:03:45): 591 / 918 seconds (64.4 %)\n", + "camera_0_progress (00:03:45): 592 / 919 seconds (64.4 %)\n", + "camera_2_progress (00:03:45): 592 / 918 seconds (64.5 %)\n", + "camera_1_progress (00:03:46): 594 / 918 seconds (64.7 %)\n", + "camera_3_progress (00:03:46): 594 / 918 seconds (64.7 %)\n", + "camera_0_progress (00:03:46): 595 / 919 seconds (64.7 %)\n", + "camera_2_progress (00:03:46): 594 / 918 seconds (64.7 %)\n", + "camera_0_progress (00:03:47): 597 / 919 seconds (65.0 %)\n", + "camera_2_progress (00:03:47): 596 / 918 seconds (64.9 %)\n", + "camera_1_progress (00:03:47): 597 / 918 seconds (65.0 %)\n", + "camera_3_progress (00:03:47): 596 / 918 seconds (64.9 %)\n", + "camera_1_progress (00:03:48): 599 / 918 seconds (65.3 %)\n", + "camera_3_progress (00:03:48): 599 / 918 seconds (65.3 %)\n", + "camera_0_progress (00:03:48): 600 / 919 seconds (65.3 %)\n", + "camera_2_progress (00:03:48): 599 / 918 seconds (65.3 %)\n", + "camera_1_progress (00:03:49): 602 / 918 seconds (65.6 %)\n", + "camera_2_progress (00:03:49): 601 / 918 seconds (65.5 %)\n", + "camera_3_progress (00:03:49): 601 / 918 seconds (65.5 %)\n", + "camera_0_progress (00:03:49): 602 / 919 seconds (65.5 %)\n", + "camera_0_progress (00:03:50): 605 / 919 seconds (65.8 %)\n", + "camera_2_progress (00:03:50): 604 / 918 seconds (65.8 %)\n", + "camera_1_progress (00:03:50): 604 / 918 seconds (65.8 %)\n", + "camera_3_progress (00:03:50): 604 / 918 seconds (65.8 %)\n", + "camera_0_progress (00:03:51): 607 / 919 seconds (66.1 %)\n", + "camera_2_progress (00:03:51): 606 / 918 seconds (66.0 %)\n", + "camera_1_progress (00:03:51): 607 / 918 seconds (66.1 %)\n", + "camera_3_progress (00:03:51): 607 / 918 seconds (66.1 %)\n", + "camera_1_progress (00:03:52): 609 / 918 seconds (66.3 %)\n", + "camera_3_progress (00:03:52): 609 / 918 seconds (66.3 %)\n", + "camera_0_progress (00:03:52): 610 / 919 seconds (66.4 %)\n", + "camera_2_progress (00:03:52): 609 / 918 seconds (66.3 %)\n", + "camera_1_progress (00:03:53): 612 / 918 seconds (66.7 %)\n", + "camera_3_progress (00:03:53): 611 / 918 seconds (66.6 %)\n", + "camera_0_progress (00:03:53): 612 / 919 seconds (66.6 %)\n", + "camera_2_progress (00:03:53): 611 / 918 seconds (66.6 %)\n", + "camera_1_progress (00:03:54): 614 / 918 seconds (66.9 %)\n", + "camera_3_progress (00:03:54): 614 / 918 seconds (66.9 %)\n", + "camera_0_progress (00:03:54): 615 / 919 seconds (66.9 %)\n", + "camera_2_progress (00:03:54): 614 / 918 seconds (66.9 %)\n", + "camera_1_progress (00:03:55): 617 / 918 seconds (67.2 %)\n", + "camera_3_progress (00:03:55): 616 / 918 seconds (67.1 %)\n", + "camera_0_progress (00:03:55): 617 / 919 seconds (67.1 %)\n", + "camera_2_progress (00:03:55): 617 / 918 seconds (67.2 %)\n", + "camera_2_progress (00:03:56): 619 / 918 seconds (67.4 %)\n", + "camera_1_progress (00:03:56): 619 / 918 seconds (67.4 %)\n", + "camera_3_progress (00:03:56): 619 / 918 seconds (67.4 %)\n", + "camera_0_progress (00:03:56): 620 / 919 seconds (67.5 %)\n", + "camera_0_progress (00:03:57): 622 / 919 seconds (67.7 %)\n", + "camera_2_progress (00:03:57): 621 / 918 seconds (67.6 %)\n", + "camera_1_progress (00:03:57): 622 / 918 seconds (67.8 %)\n", + "camera_3_progress (00:03:57): 621 / 918 seconds (67.6 %)\n", + "camera_0_progress (00:03:58): 625 / 919 seconds (68.0 %)\n", + "camera_2_progress (00:03:58): 624 / 918 seconds (68.0 %)\n", + "camera_1_progress (00:03:58): 624 / 918 seconds (68.0 %)\n", + "camera_3_progress (00:03:58): 624 / 918 seconds (68.0 %)\n", + "camera_1_progress (00:03:59): 627 / 918 seconds (68.3 %)\n", + "camera_3_progress (00:03:59): 626 / 918 seconds (68.2 %)\n", + "camera_0_progress (00:03:59): 627 / 919 seconds (68.2 %)\n", + "camera_2_progress (00:03:59): 627 / 918 seconds (68.3 %)\n", + "camera_1_progress (00:04:00): 629 / 918 seconds (68.5 %)\n", + "camera_3_progress (00:04:00): 629 / 918 seconds (68.5 %)\n", + "camera_0_progress (00:04:00): 630 / 919 seconds (68.6 %)\n", + "camera_2_progress (00:04:00): 629 / 918 seconds (68.5 %)\n", + "camera_1_progress (00:04:01): 632 / 918 seconds (68.8 %)\n", + "camera_3_progress (00:04:01): 631 / 918 seconds (68.7 %)\n", + "camera_0_progress (00:04:01): 632 / 919 seconds (68.8 %)\n", + "camera_2_progress (00:04:01): 631 / 918 seconds (68.7 %)\n", + "camera_3_progress (00:04:02): 634 / 918 seconds (69.1 %)\n", + "camera_0_progress (00:04:02): 635 / 919 seconds (69.1 %)\n", + "camera_2_progress (00:04:02): 634 / 918 seconds (69.1 %)\n", + "camera_1_progress (00:04:02): 634 / 918 seconds (69.1 %)\n", + "camera_2_progress (00:04:03): 636 / 918 seconds (69.3 %)\n", + "camera_1_progress (00:04:03): 637 / 918 seconds (69.4 %)\n", + "camera_3_progress (00:04:03): 636 / 918 seconds (69.3 %)\n", + "camera_0_progress (00:04:03): 637 / 919 seconds (69.3 %)\n", + "camera_1_progress (00:04:04): 639 / 918 seconds (69.6 %)\n", + "camera_3_progress (00:04:04): 639 / 918 seconds (69.6 %)\n", + "camera_0_progress (00:04:04): 640 / 919 seconds (69.6 %)\n", + "camera_2_progress (00:04:04): 639 / 918 seconds (69.6 %)\n", + "camera_2_progress (00:04:05): 641 / 918 seconds (69.8 %)\n", + "camera_1_progress (00:04:05): 642 / 918 seconds (69.9 %)\n", + "camera_3_progress (00:04:05): 641 / 918 seconds (69.8 %)\n", + "camera_0_progress (00:04:05): 642 / 919 seconds (69.9 %)\n", + "camera_1_progress (00:04:06): 644 / 918 seconds (70.2 %)\n", + "camera_3_progress (00:04:06): 644 / 918 seconds (70.2 %)\n", + "camera_0_progress (00:04:06): 645 / 919 seconds (70.2 %)\n", + "camera_2_progress (00:04:06): 644 / 918 seconds (70.2 %)\n", + "camera_1_progress (00:04:07): 647 / 918 seconds (70.5 %)\n", + "camera_3_progress (00:04:07): 646 / 918 seconds (70.4 %)\n", + "camera_0_progress (00:04:07): 647 / 919 seconds (70.4 %)\n", + "camera_2_progress (00:04:07): 647 / 918 seconds (70.5 %)\n", + "camera_0_progress (00:04:08): 650 / 919 seconds (70.7 %)\n", + "camera_2_progress (00:04:08): 649 / 918 seconds (70.7 %)\n", + "camera_1_progress (00:04:08): 649 / 918 seconds (70.7 %)\n", + "camera_3_progress (00:04:08): 649 / 918 seconds (70.7 %)\n", + "camera_3_progress (00:04:09): 651 / 918 seconds (70.9 %)\n", + "camera_0_progress (00:04:09): 652 / 919 seconds (70.9 %)\n", + "camera_2_progress (00:04:09): 652 / 918 seconds (71.0 %)\n", + "camera_1_progress (00:04:09): 652 / 918 seconds (71.0 %)\n", + "camera_2_progress (00:04:10): 654 / 918 seconds (71.2 %)\n", + "camera_1_progress (00:04:10): 654 / 918 seconds (71.2 %)\n", + "camera_3_progress (00:04:10): 654 / 918 seconds (71.2 %)\n", + "camera_0_progress (00:04:10): 655 / 919 seconds (71.3 %)\n", + "camera_3_progress (00:04:11): 656 / 918 seconds (71.5 %)\n", + "camera_0_progress (00:04:11): 657 / 919 seconds (71.5 %)\n", + "camera_2_progress (00:04:11): 656 / 918 seconds (71.5 %)\n", + "camera_1_progress (00:04:11): 657 / 918 seconds (71.6 %)\n", + "camera_2_progress (00:04:12): 659 / 918 seconds (71.8 %)\n", + "camera_1_progress (00:04:12): 659 / 918 seconds (71.8 %)\n", + "camera_3_progress (00:04:12): 659 / 918 seconds (71.8 %)\n", + "camera_0_progress (00:04:12): 660 / 919 seconds (71.8 %)\n", + "camera_3_progress (00:04:13): 661 / 918 seconds (72.0 %)\n", + "camera_0_progress (00:04:13): 662 / 919 seconds (72.0 %)\n", + "camera_2_progress (00:04:13): 662 / 918 seconds (72.1 %)\n", + "camera_1_progress (00:04:13): 662 / 918 seconds (72.1 %)\n", + "camera_3_progress (00:04:14): 664 / 918 seconds (72.3 %)\n", + "camera_0_progress (00:04:14): 665 / 919 seconds (72.4 %)\n", + "camera_2_progress (00:04:14): 664 / 918 seconds (72.3 %)\n", + "camera_1_progress (00:04:14): 664 / 918 seconds (72.3 %)\n", + "camera_3_progress (00:04:15): 666 / 918 seconds (72.5 %)\n", + "camera_0_progress (00:04:15): 667 / 919 seconds (72.6 %)\n", + "camera_2_progress (00:04:15): 666 / 918 seconds (72.5 %)\n", + "camera_1_progress (00:04:15): 667 / 918 seconds (72.7 %)\n", + "camera_3_progress (00:04:16): 669 / 918 seconds (72.9 %)\n", + "camera_0_progress (00:04:16): 670 / 919 seconds (72.9 %)\n", + "camera_2_progress (00:04:16): 669 / 918 seconds (72.9 %)\n", + "camera_1_progress (00:04:16): 669 / 918 seconds (72.9 %)\n", + "camera_0_progress (00:04:17): 672 / 919 seconds (73.1 %)\n", + "camera_2_progress (00:04:17): 672 / 918 seconds (73.2 %)\n", + "camera_1_progress (00:04:17): 672 / 918 seconds (73.2 %)\n", + "camera_3_progress (00:04:17): 671 / 918 seconds (73.1 %)\n", + "camera_1_progress (00:04:18): 674 / 918 seconds (73.4 %)\n", + "camera_3_progress (00:04:18): 674 / 918 seconds (73.4 %)\n", + "camera_0_progress (00:04:18): 675 / 919 seconds (73.4 %)\n", + "camera_2_progress (00:04:18): 674 / 918 seconds (73.4 %)\n", + "camera_0_progress (00:04:19): 677 / 919 seconds (73.7 %)\n", + "camera_2_progress (00:04:19): 677 / 918 seconds (73.7 %)\n", + "camera_1_progress (00:04:19): 677 / 918 seconds (73.7 %)\n", + "camera_3_progress (00:04:19): 676 / 918 seconds (73.6 %)\n", + "camera_3_progress (00:04:20): 679 / 918 seconds (74.0 %)\n", + "camera_0_progress (00:04:20): 680 / 919 seconds (74.0 %)\n", + "camera_2_progress (00:04:20): 679 / 918 seconds (74.0 %)\n", + "camera_1_progress (00:04:20): 679 / 918 seconds (74.0 %)\n", + "camera_1_progress (00:04:21): 682 / 918 seconds (74.3 %)\n", + "camera_3_progress (00:04:21): 681 / 918 seconds (74.2 %)\n", + "camera_0_progress (00:04:21): 682 / 919 seconds (74.2 %)\n", + "camera_2_progress (00:04:21): 681 / 918 seconds (74.2 %)\n", + "camera_0_progress (00:04:22): 684 / 919 seconds (74.4 %)\n", + "camera_2_progress (00:04:22): 684 / 918 seconds (74.5 %)\n", + "camera_1_progress (00:04:22): 684 / 918 seconds (74.5 %)\n", + "camera_3_progress (00:04:22): 684 / 918 seconds (74.5 %)\n", + "camera_0_progress (00:04:23): 687 / 919 seconds (74.8 %)\n", + "camera_2_progress (00:04:23): 686 / 918 seconds (74.7 %)\n", + "camera_1_progress (00:04:23): 686 / 918 seconds (74.7 %)\n", + "camera_3_progress (00:04:23): 686 / 918 seconds (74.7 %)\n", + "camera_3_progress (00:04:24): 688 / 918 seconds (74.9 %)\n", + "camera_0_progress (00:04:24): 689 / 919 seconds (75.0 %)\n", + "camera_2_progress (00:04:24): 689 / 918 seconds (75.1 %)\n", + "camera_1_progress (00:04:24): 689 / 918 seconds (75.1 %)\n", + "camera_3_progress (00:04:25): 691 / 918 seconds (75.3 %)\n", + "camera_0_progress (00:04:25): 692 / 919 seconds (75.3 %)\n", + "camera_2_progress (00:04:25): 691 / 918 seconds (75.3 %)\n", + "camera_1_progress (00:04:25): 692 / 918 seconds (75.4 %)\n", + "camera_0_progress (00:04:26): 695 / 919 seconds (75.6 %)\n", + "camera_2_progress (00:04:26): 694 / 918 seconds (75.6 %)\n", + "camera_1_progress (00:04:26): 694 / 918 seconds (75.6 %)\n", + "camera_3_progress (00:04:26): 694 / 918 seconds (75.6 %)\n", + "camera_0_progress (00:04:27): 697 / 919 seconds (75.8 %)\n", + "camera_2_progress (00:04:27): 696 / 918 seconds (75.8 %)\n", + "camera_1_progress (00:04:27): 697 / 918 seconds (75.9 %)\n", + "camera_3_progress (00:04:27): 696 / 918 seconds (75.8 %)\n", + "camera_0_progress (00:04:28): 699 / 919 seconds (76.1 %)\n", + "camera_2_progress (00:04:28): 699 / 918 seconds (76.1 %)\n", + "camera_1_progress (00:04:28): 699 / 918 seconds (76.1 %)\n", + "camera_3_progress (00:04:28): 698 / 918 seconds (76.0 %)\n", + "camera_3_progress (00:04:29): 701 / 918 seconds (76.4 %)\n", + "camera_0_progress (00:04:29): 702 / 919 seconds (76.4 %)\n", + "camera_2_progress (00:04:29): 701 / 918 seconds (76.4 %)\n", + "camera_1_progress (00:04:29): 702 / 918 seconds (76.5 %)\n", + "camera_2_progress (00:04:30): 703 / 918 seconds (76.6 %)\n", + "camera_1_progress (00:04:30): 704 / 918 seconds (76.7 %)\n", + "camera_3_progress (00:04:30): 703 / 918 seconds (76.6 %)\n", + "camera_0_progress (00:04:30): 704 / 919 seconds (76.6 %)\n", + "camera_3_progress (00:04:31): 705 / 918 seconds (76.8 %)\n", + "camera_0_progress (00:04:31): 707 / 919 seconds (76.9 %)\n", + "camera_2_progress (00:04:31): 706 / 918 seconds (76.9 %)\n", + "camera_1_progress (00:04:31): 706 / 918 seconds (76.9 %)\n", + "camera_1_progress (00:04:32): 708 / 918 seconds (77.1 %)\n", + "camera_3_progress (00:04:32): 708 / 918 seconds (77.1 %)\n", + "camera_0_progress (00:04:32): 709 / 919 seconds (77.1 %)\n", + "camera_2_progress (00:04:32): 708 / 918 seconds (77.1 %)\n", + "camera_1_progress (00:04:33): 711 / 918 seconds (77.5 %)\n", + "camera_3_progress (00:04:33): 710 / 918 seconds (77.3 %)\n", + "camera_0_progress (00:04:33): 711 / 919 seconds (77.4 %)\n", + "camera_2_progress (00:04:33): 711 / 918 seconds (77.5 %)\n", + "camera_3_progress (00:04:34): 713 / 918 seconds (77.7 %)\n", + "camera_0_progress (00:04:34): 714 / 919 seconds (77.7 %)\n", + "camera_2_progress (00:04:34): 713 / 918 seconds (77.7 %)\n", + "camera_1_progress (00:04:34): 713 / 918 seconds (77.7 %)\n", + "camera_3_progress (00:04:35): 715 / 918 seconds (77.9 %)\n", + "camera_0_progress (00:04:35): 716 / 919 seconds (77.9 %)\n", + "camera_2_progress (00:04:35): 716 / 918 seconds (78.0 %)\n", + "camera_1_progress (00:04:35): 716 / 918 seconds (78.0 %)\n", + "camera_1_progress (00:04:36): 718 / 918 seconds (78.2 %)\n", + "camera_3_progress (00:04:36): 718 / 918 seconds (78.2 %)\n", + "camera_0_progress (00:04:36): 719 / 919 seconds (78.2 %)\n", + "camera_2_progress (00:04:36): 718 / 918 seconds (78.2 %)\n", + "camera_2_progress (00:04:37): 720 / 918 seconds (78.4 %)\n", + "camera_1_progress (00:04:37): 721 / 918 seconds (78.5 %)\n", + "camera_3_progress (00:04:37): 720 / 918 seconds (78.4 %)\n", + "camera_0_progress (00:04:37): 721 / 919 seconds (78.5 %)\n", + "camera_0_progress (00:04:38): 723 / 919 seconds (78.7 %)\n", + "camera_2_progress (00:04:38): 723 / 918 seconds (78.8 %)\n", + "camera_1_progress (00:04:38): 723 / 918 seconds (78.8 %)\n", + "camera_3_progress (00:04:38): 722 / 918 seconds (78.6 %)\n", + "camera_3_progress (00:04:39): 725 / 918 seconds (79.0 %)\n", + "camera_0_progress (00:04:39): 726 / 919 seconds (79.0 %)\n", + "camera_2_progress (00:04:39): 725 / 918 seconds (79.0 %)\n", + "camera_1_progress (00:04:39): 726 / 918 seconds (79.1 %)\n", + "camera_0_progress (00:04:40): 729 / 919 seconds (79.3 %)\n", + "camera_2_progress (00:04:40): 728 / 918 seconds (79.3 %)\n", + "camera_1_progress (00:04:40): 728 / 918 seconds (79.3 %)\n", + "camera_3_progress (00:04:40): 728 / 918 seconds (79.3 %)\n", + "camera_0_progress (00:04:41): 731 / 919 seconds (79.5 %)\n", + "camera_2_progress (00:04:41): 731 / 918 seconds (79.6 %)\n", + "camera_1_progress (00:04:41): 731 / 918 seconds (79.6 %)\n", + "camera_3_progress (00:04:41): 730 / 918 seconds (79.5 %)\n", + "camera_3_progress (00:04:42): 733 / 918 seconds (79.8 %)\n", + "camera_0_progress (00:04:42): 734 / 919 seconds (79.9 %)\n", + "camera_2_progress (00:04:42): 733 / 918 seconds (79.8 %)\n", + "camera_1_progress (00:04:42): 733 / 918 seconds (79.8 %)\n", + "camera_0_progress (00:04:43): 736 / 919 seconds (80.1 %)\n", + "camera_2_progress (00:04:43): 735 / 918 seconds (80.1 %)\n", + "camera_1_progress (00:04:43): 736 / 918 seconds (80.2 %)\n", + "camera_3_progress (00:04:43): 735 / 918 seconds (80.1 %)\n", + "camera_3_progress (00:04:44): 738 / 918 seconds (80.4 %)\n", + "camera_0_progress (00:04:44): 739 / 919 seconds (80.4 %)\n", + "camera_2_progress (00:04:44): 738 / 918 seconds (80.4 %)\n", + "camera_1_progress (00:04:44): 738 / 918 seconds (80.4 %)\n", + "camera_0_progress (00:04:45): 741 / 919 seconds (80.6 %)\n", + "camera_2_progress (00:04:45): 740 / 918 seconds (80.6 %)\n", + "camera_1_progress (00:04:45): 741 / 918 seconds (80.7 %)\n", + "camera_3_progress (00:04:45): 740 / 918 seconds (80.6 %)\n", + "camera_0_progress (00:04:46): 744 / 919 seconds (81.0 %)\n", + "camera_2_progress (00:04:46): 743 / 918 seconds (80.9 %)\n", + "camera_1_progress (00:04:46): 743 / 918 seconds (80.9 %)\n", + "camera_3_progress (00:04:46): 743 / 918 seconds (80.9 %)\n", + "camera_1_progress (00:04:47): 746 / 918 seconds (81.3 %)\n", + "camera_3_progress (00:04:47): 745 / 918 seconds (81.2 %)\n", + "camera_0_progress (00:04:47): 746 / 919 seconds (81.2 %)\n", + "camera_2_progress (00:04:47): 746 / 918 seconds (81.3 %)\n", + "camera_3_progress (00:04:48): 748 / 918 seconds (81.5 %)\n", + "camera_0_progress (00:04:48): 749 / 919 seconds (81.5 %)\n", + "camera_2_progress (00:04:48): 748 / 918 seconds (81.5 %)\n", + "camera_1_progress (00:04:48): 748 / 918 seconds (81.5 %)\n", + "camera_0_progress (00:04:49): 751 / 919 seconds (81.7 %)\n", + "camera_2_progress (00:04:49): 750 / 918 seconds (81.7 %)\n", + "camera_1_progress (00:04:49): 751 / 918 seconds (81.8 %)\n", + "camera_3_progress (00:04:49): 750 / 918 seconds (81.7 %)\n", + "camera_2_progress (00:04:50): 753 / 918 seconds (82.0 %)\n", + "camera_1_progress (00:04:50): 753 / 918 seconds (82.0 %)\n", + "camera_3_progress (00:04:50): 753 / 918 seconds (82.0 %)\n", + "camera_0_progress (00:04:50): 754 / 919 seconds (82.0 %)\n", + "camera_1_progress (00:04:51): 756 / 918 seconds (82.4 %)\n", + "camera_3_progress (00:04:51): 755 / 918 seconds (82.2 %)\n", + "camera_0_progress (00:04:51): 756 / 919 seconds (82.3 %)\n", + "camera_2_progress (00:04:51): 756 / 918 seconds (82.4 %)\n", + "camera_2_progress (00:04:52): 758 / 918 seconds (82.6 %)\n", + "camera_1_progress (00:04:52): 758 / 918 seconds (82.6 %)\n", + "camera_3_progress (00:04:52): 758 / 918 seconds (82.6 %)\n", + "camera_0_progress (00:04:52): 759 / 919 seconds (82.6 %)\n", + "camera_1_progress (00:04:53): 761 / 918 seconds (82.9 %)\n", + "camera_3_progress (00:04:53): 760 / 918 seconds (82.8 %)\n", + "camera_0_progress (00:04:53): 761 / 919 seconds (82.8 %)\n", + "camera_2_progress (00:04:53): 761 / 918 seconds (82.9 %)\n", + "camera_0_progress (00:04:54): 764 / 919 seconds (83.1 %)\n", + "camera_2_progress (00:04:54): 763 / 918 seconds (83.1 %)\n", + "camera_1_progress (00:04:54): 763 / 918 seconds (83.1 %)\n", + "camera_3_progress (00:04:54): 763 / 918 seconds (83.1 %)\n", + "camera_3_progress (00:04:55): 765 / 918 seconds (83.3 %)\n", + "camera_0_progress (00:04:55): 766 / 919 seconds (83.4 %)\n", + "camera_2_progress (00:04:55): 766 / 918 seconds (83.4 %)\n", + "camera_1_progress (00:04:55): 766 / 918 seconds (83.4 %)\n", + "camera_1_progress (00:04:56): 768 / 918 seconds (83.7 %)\n", + "camera_3_progress (00:04:56): 768 / 918 seconds (83.7 %)\n", + "camera_0_progress (00:04:56): 769 / 919 seconds (83.7 %)\n", + "camera_2_progress (00:04:56): 768 / 918 seconds (83.7 %)\n", + "camera_2_progress (00:04:57): 771 / 918 seconds (84.0 %)\n", + "camera_1_progress (00:04:57): 771 / 918 seconds (84.0 %)\n", + "camera_3_progress (00:04:57): 770 / 918 seconds (83.9 %)\n", + "camera_0_progress (00:04:57): 771 / 919 seconds (83.9 %)\n", + "camera_2_progress (00:04:58): 773 / 918 seconds (84.2 %)\n", + "camera_1_progress (00:04:58): 774 / 918 seconds (84.3 %)\n", + "camera_3_progress (00:04:58): 773 / 918 seconds (84.2 %)\n", + "camera_0_progress (00:04:58): 774 / 919 seconds (84.2 %)\n", + "camera_2_progress (00:04:59): 776 / 918 seconds (84.5 %)\n", + "camera_1_progress (00:04:59): 776 / 918 seconds (84.5 %)\n", + "camera_3_progress (00:04:59): 775 / 918 seconds (84.4 %)\n", + "camera_0_progress (00:04:59): 776 / 919 seconds (84.4 %)\n", + "camera_3_progress (00:05:00): 778 / 918 seconds (84.7 %)\n", + "camera_0_progress (00:05:00): 779 / 919 seconds (84.8 %)\n", + "camera_2_progress (00:05:00): 779 / 918 seconds (84.9 %)\n", + "camera_1_progress (00:05:00): 779 / 918 seconds (84.9 %)\n", + "camera_0_progress (00:05:01): 782 / 919 seconds (85.1 %)\n", + "camera_2_progress (00:05:01): 781 / 918 seconds (85.1 %)\n", + "camera_1_progress (00:05:01): 781 / 918 seconds (85.1 %)\n", + "camera_3_progress (00:05:01): 781 / 918 seconds (85.1 %)\n", + "camera_2_progress (00:05:02): 784 / 918 seconds (85.4 %)\n", + "camera_1_progress (00:05:02): 784 / 918 seconds (85.4 %)\n", + "camera_3_progress (00:05:02): 783 / 918 seconds (85.3 %)\n", + "camera_0_progress (00:05:02): 784 / 919 seconds (85.3 %)\n", + "camera_2_progress (00:05:03): 786 / 918 seconds (85.6 %)\n", + "camera_1_progress (00:05:03): 786 / 918 seconds (85.6 %)\n", + "camera_3_progress (00:05:03): 786 / 918 seconds (85.6 %)\n", + "camera_0_progress (00:05:03): 787 / 919 seconds (85.6 %)\n", + "camera_2_progress (00:05:04): 788 / 918 seconds (85.8 %)\n", + "camera_1_progress (00:05:04): 789 / 918 seconds (85.9 %)\n", + "camera_3_progress (00:05:04): 788 / 918 seconds (85.8 %)\n", + "camera_0_progress (00:05:04): 789 / 919 seconds (85.9 %)\n", + "camera_0_progress (00:05:05): 792 / 919 seconds (86.2 %)\n", + "camera_2_progress (00:05:05): 791 / 918 seconds (86.2 %)\n", + "camera_1_progress (00:05:05): 791 / 918 seconds (86.2 %)\n", + "camera_3_progress (00:05:05): 791 / 918 seconds (86.2 %)\n", + "camera_3_progress (00:05:06): 793 / 918 seconds (86.4 %)\n", + "camera_0_progress (00:05:06): 794 / 919 seconds (86.4 %)\n", + "camera_2_progress (00:05:06): 793 / 918 seconds (86.4 %)\n", + "camera_1_progress (00:05:06): 794 / 918 seconds (86.5 %)\n", + "camera_2_progress (00:05:07): 796 / 918 seconds (86.7 %)\n", + "camera_0_progress (00:05:07): 797 / 919 seconds (86.7 %)\n", + "camera_1_progress (00:05:07): 796 / 918 seconds (86.7 %)\n", + "camera_3_progress (00:05:07): 796 / 918 seconds (86.7 %)\n", + "camera_3_progress (00:05:08): 798 / 918 seconds (86.9 %)\n", + "camera_0_progress (00:05:08): 799 / 919 seconds (86.9 %)\n", + "camera_2_progress (00:05:08): 799 / 918 seconds (87.0 %)\n", + "camera_1_progress (00:05:08): 799 / 918 seconds (87.0 %)\n", + "camera_3_progress (00:05:09): 801 / 918 seconds (87.3 %)\n", + "camera_0_progress (00:05:09): 802 / 919 seconds (87.3 %)\n", + "camera_2_progress (00:05:09): 801 / 918 seconds (87.3 %)\n", + "camera_1_progress (00:05:09): 802 / 918 seconds (87.4 %)\n", + "camera_1_progress (00:05:10): 804 / 918 seconds (87.6 %)\n", + "camera_3_progress (00:05:10): 803 / 918 seconds (87.5 %)\n", + "camera_0_progress (00:05:10): 804 / 919 seconds (87.5 %)\n", + "camera_2_progress (00:05:10): 804 / 918 seconds (87.6 %)\n", + "camera_1_progress (00:05:11): 806 / 918 seconds (87.8 %)\n", + "camera_3_progress (00:05:11): 806 / 918 seconds (87.8 %)\n", + "camera_0_progress (00:05:11): 807 / 919 seconds (87.8 %)\n", + "camera_2_progress (00:05:11): 806 / 918 seconds (87.8 %)\n", + "camera_0_progress (00:05:12): 809 / 919 seconds (88.0 %)\n", + "camera_2_progress (00:05:12): 808 / 918 seconds (88.0 %)\n", + "camera_1_progress (00:05:12): 809 / 918 seconds (88.1 %)\n", + "camera_3_progress (00:05:12): 808 / 918 seconds (88.0 %)\n", + "camera_0_progress (00:05:13): 812 / 919 seconds (88.4 %)\n", + "camera_2_progress (00:05:13): 811 / 918 seconds (88.3 %)\n", + "camera_1_progress (00:05:13): 811 / 918 seconds (88.3 %)\n", + "camera_3_progress (00:05:13): 811 / 918 seconds (88.3 %)\n", + "camera_2_progress (00:05:14): 814 / 918 seconds (88.7 %)\n", + "camera_1_progress (00:05:14): 814 / 918 seconds (88.7 %)\n", + "camera_3_progress (00:05:14): 813 / 918 seconds (88.6 %)\n", + "camera_0_progress (00:05:14): 814 / 919 seconds (88.6 %)\n", + "camera_2_progress (00:05:15): 816 / 918 seconds (88.9 %)\n", + "camera_1_progress (00:05:15): 816 / 918 seconds (88.9 %)\n", + "camera_3_progress (00:05:15): 816 / 918 seconds (88.9 %)\n", + "camera_0_progress (00:05:15): 817 / 919 seconds (88.9 %)\n", + "camera_3_progress (00:05:16): 818 / 918 seconds (89.1 %)\n", + "camera_0_progress (00:05:16): 819 / 919 seconds (89.1 %)\n", + "camera_2_progress (00:05:16): 819 / 918 seconds (89.2 %)\n", + "camera_1_progress (00:05:16): 819 / 918 seconds (89.2 %)\n", + "camera_0_progress (00:05:17): 822 / 919 seconds (89.4 %)\n", + "camera_2_progress (00:05:17): 821 / 918 seconds (89.4 %)\n", + "camera_1_progress (00:05:17): 821 / 918 seconds (89.4 %)\n", + "camera_3_progress (00:05:17): 821 / 918 seconds (89.4 %)\n", + "camera_1_progress (00:05:18): 824 / 918 seconds (89.8 %)\n", + "camera_3_progress (00:05:18): 823 / 918 seconds (89.7 %)\n", + "camera_0_progress (00:05:18): 824 / 919 seconds (89.7 %)\n", + "camera_2_progress (00:05:18): 824 / 918 seconds (89.8 %)\n", + "camera_1_progress (00:05:19): 826 / 918 seconds (90.0 %)\n", + "camera_3_progress (00:05:19): 825 / 918 seconds (89.9 %)\n", + "camera_0_progress (00:05:19): 826 / 919 seconds (89.9 %)\n", + "camera_2_progress (00:05:19): 826 / 918 seconds (90.0 %)\n", + "camera_1_progress (00:05:20): 828 / 918 seconds (90.2 %)\n", + "camera_3_progress (00:05:20): 828 / 918 seconds (90.2 %)\n", + "camera_0_progress (00:05:20): 829 / 919 seconds (90.2 %)\n", + "camera_2_progress (00:05:20): 828 / 918 seconds (90.2 %)\n", + "camera_2_progress (00:05:21): 831 / 918 seconds (90.5 %)\n", + "camera_1_progress (00:05:21): 831 / 918 seconds (90.5 %)\n", + "camera_3_progress (00:05:21): 830 / 918 seconds (90.4 %)\n", + "camera_0_progress (00:05:21): 831 / 919 seconds (90.4 %)\n", + "camera_3_progress (00:05:22): 833 / 918 seconds (90.7 %)\n", + "camera_0_progress (00:05:22): 834 / 919 seconds (90.8 %)\n", + "camera_2_progress (00:05:22): 833 / 918 seconds (90.7 %)\n", + "camera_1_progress (00:05:22): 833 / 918 seconds (90.7 %)\n", + "camera_0_progress (00:05:23): 836 / 919 seconds (91.0 %)\n", + "camera_2_progress (00:05:23): 835 / 918 seconds (91.0 %)\n", + "camera_1_progress (00:05:23): 836 / 918 seconds (91.1 %)\n", + "camera_3_progress (00:05:23): 835 / 918 seconds (91.0 %)\n", + "camera_0_progress (00:05:24): 838 / 919 seconds (91.2 %)\n", + "camera_2_progress (00:05:24): 838 / 918 seconds (91.3 %)\n", + "camera_1_progress (00:05:24): 838 / 918 seconds (91.3 %)\n", + "camera_3_progress (00:05:24): 838 / 918 seconds (91.3 %)\n", + "camera_3_progress (00:05:25): 840 / 918 seconds (91.5 %)\n", + "camera_0_progress (00:05:25): 841 / 919 seconds (91.5 %)\n", + "camera_2_progress (00:05:25): 840 / 918 seconds (91.5 %)\n", + "camera_1_progress (00:05:25): 840 / 918 seconds (91.5 %)\n", + "camera_2_progress (00:05:26): 843 / 918 seconds (91.8 %)\n", + "camera_1_progress (00:05:26): 843 / 918 seconds (91.8 %)\n", + "camera_3_progress (00:05:26): 842 / 918 seconds (91.7 %)\n", + "camera_0_progress (00:05:26): 843 / 919 seconds (91.7 %)\n", + "camera_2_progress (00:05:27): 845 / 918 seconds (92.0 %)\n", + "camera_1_progress (00:05:27): 845 / 918 seconds (92.0 %)\n", + "camera_3_progress (00:05:27): 845 / 918 seconds (92.0 %)\n", + "camera_0_progress (00:05:27): 846 / 919 seconds (92.1 %)\n", + "camera_2_progress (00:05:28): 848 / 918 seconds (92.4 %)\n", + "camera_1_progress (00:05:28): 848 / 918 seconds (92.4 %)\n", + "camera_3_progress (00:05:28): 847 / 918 seconds (92.3 %)\n", + "camera_0_progress (00:05:28): 848 / 919 seconds (92.3 %)\n", + "camera_2_progress (00:05:29): 850 / 918 seconds (92.6 %)\n", + "camera_1_progress (00:05:29): 850 / 918 seconds (92.6 %)\n", + "camera_3_progress (00:05:29): 850 / 918 seconds (92.6 %)\n", + "camera_0_progress (00:05:29): 851 / 919 seconds (92.6 %)\n", + "camera_0_progress (00:05:30): 853 / 919 seconds (92.8 %)\n", + "camera_2_progress (00:05:30): 853 / 918 seconds (92.9 %)\n", + "camera_1_progress (00:05:30): 853 / 918 seconds (92.9 %)\n", + "camera_3_progress (00:05:30): 852 / 918 seconds (92.8 %)\n", + "camera_1_progress (00:05:31): 856 / 918 seconds (93.2 %)\n", + "camera_3_progress (00:05:31): 855 / 918 seconds (93.1 %)\n", + "camera_0_progress (00:05:31): 856 / 919 seconds (93.1 %)\n", + "camera_2_progress (00:05:31): 856 / 918 seconds (93.2 %)\n", + "camera_1_progress (00:05:32): 858 / 918 seconds (93.5 %)\n", + "camera_3_progress (00:05:32): 858 / 918 seconds (93.5 %)\n", + "camera_0_progress (00:05:32): 859 / 919 seconds (93.5 %)\n", + "camera_2_progress (00:05:32): 858 / 918 seconds (93.5 %)\n", + "camera_0_progress (00:05:33): 861 / 919 seconds (93.7 %)\n", + "camera_2_progress (00:05:33): 860 / 918 seconds (93.7 %)\n", + "camera_3_progress (00:05:33): 860 / 918 seconds (93.7 %)\n", + "camera_1_progress (00:05:33): 861 / 918 seconds (93.8 %)\n", + "camera_0_progress (00:05:34): 864 / 919 seconds (94.0 %)\n", + "camera_2_progress (00:05:34): 863 / 918 seconds (94.0 %)\n", + "camera_1_progress (00:05:34): 863 / 918 seconds (94.0 %)\n", + "camera_3_progress (00:05:34): 863 / 918 seconds (94.0 %)\n", + "camera_2_progress (00:05:35): 865 / 918 seconds (94.2 %)\n", + "camera_1_progress (00:05:35): 866 / 918 seconds (94.3 %)\n", + "camera_3_progress (00:05:35): 865 / 918 seconds (94.2 %)\n", + "camera_0_progress (00:05:35): 866 / 919 seconds (94.2 %)\n", + "camera_0_progress (00:05:36): 869 / 919 seconds (94.6 %)\n", + "camera_2_progress (00:05:36): 868 / 918 seconds (94.6 %)\n", + "camera_1_progress (00:05:36): 868 / 918 seconds (94.6 %)\n", + "camera_3_progress (00:05:36): 868 / 918 seconds (94.6 %)\n", + "camera_3_progress (00:05:37): 870 / 918 seconds (94.8 %)\n", + "camera_0_progress (00:05:37): 871 / 919 seconds (94.8 %)\n", + "camera_2_progress (00:05:37): 871 / 918 seconds (94.9 %)\n", + "camera_1_progress (00:05:37): 871 / 918 seconds (94.9 %)\n", + "camera_3_progress (00:05:38): 873 / 918 seconds (95.1 %)\n", + "camera_0_progress (00:05:38): 874 / 919 seconds (95.1 %)\n", + "camera_2_progress (00:05:38): 873 / 918 seconds (95.1 %)\n", + "camera_1_progress (00:05:38): 874 / 918 seconds (95.2 %)\n", + "camera_0_progress (00:05:39): 876 / 919 seconds (95.3 %)\n", + "camera_2_progress (00:05:39): 876 / 918 seconds (95.4 %)\n", + "camera_1_progress (00:05:39): 876 / 918 seconds (95.4 %)\n", + "camera_3_progress (00:05:39): 876 / 918 seconds (95.4 %)\n", + "camera_0_progress (00:05:40): 879 / 919 seconds (95.6 %)\n", + "camera_2_progress (00:05:40): 878 / 918 seconds (95.6 %)\n", + "camera_1_progress (00:05:40): 878 / 918 seconds (95.6 %)\n", + "camera_3_progress (00:05:40): 878 / 918 seconds (95.6 %)\n", + "camera_1_progress (00:05:41): 881 / 918 seconds (96.0 %)\n", + "camera_3_progress (00:05:41): 880 / 918 seconds (95.9 %)\n", + "camera_0_progress (00:05:41): 881 / 919 seconds (95.9 %)\n", + "camera_2_progress (00:05:41): 881 / 918 seconds (96.0 %)\n", + "camera_1_progress (00:05:42): 884 / 918 seconds (96.3 %)\n", + "camera_3_progress (00:05:42): 883 / 918 seconds (96.2 %)\n", + "camera_0_progress (00:05:42): 884 / 919 seconds (96.2 %)\n", + "camera_2_progress (00:05:42): 883 / 918 seconds (96.2 %)\n", + "camera_1_progress (00:05:43): 886 / 918 seconds (96.5 %)\n", + "camera_3_progress (00:05:43): 886 / 918 seconds (96.5 %)\n", + "camera_0_progress (00:05:43): 887 / 919 seconds (96.5 %)\n", + "camera_2_progress (00:05:43): 886 / 918 seconds (96.5 %)\n", + "camera_3_progress (00:05:44): 888 / 918 seconds (96.7 %)\n", + "camera_0_progress (00:05:44): 889 / 919 seconds (96.7 %)\n", + "camera_2_progress (00:05:44): 889 / 918 seconds (96.8 %)\n", + "camera_1_progress (00:05:44): 889 / 918 seconds (96.8 %)\n", + "camera_2_progress (00:05:45): 891 / 918 seconds (97.1 %)\n", + "camera_1_progress (00:05:45): 891 / 918 seconds (97.1 %)\n", + "camera_3_progress (00:05:45): 891 / 918 seconds (97.1 %)\n", + "camera_0_progress (00:05:45): 892 / 919 seconds (97.1 %)\n", + "camera_0_progress (00:05:46): 894 / 919 seconds (97.3 %)\n", + "camera_2_progress (00:05:46): 893 / 918 seconds (97.3 %)\n", + "camera_1_progress (00:05:46): 894 / 918 seconds (97.4 %)\n", + "camera_3_progress (00:05:46): 893 / 918 seconds (97.3 %)\n", + "camera_0_progress (00:05:47): 897 / 919 seconds (97.6 %)\n", + "camera_2_progress (00:05:47): 896 / 918 seconds (97.6 %)\n", + "camera_1_progress (00:05:47): 896 / 918 seconds (97.6 %)\n", + "camera_3_progress (00:05:47): 896 / 918 seconds (97.6 %)\n", + "camera_3_progress (00:05:48): 899 / 918 seconds (97.9 %)\n", + "camera_0_progress (00:05:48): 900 / 919 seconds (97.9 %)\n", + "camera_2_progress (00:05:48): 899 / 918 seconds (97.9 %)\n", + "camera_1_progress (00:05:48): 899 / 918 seconds (97.9 %)\n", + "camera_2_progress (00:05:49): 902 / 918 seconds (98.3 %)\n", + "camera_1_progress (00:05:49): 902 / 918 seconds (98.3 %)\n", + "camera_3_progress (00:05:49): 901 / 918 seconds (98.1 %)\n", + "camera_0_progress (00:05:49): 902 / 919 seconds (98.2 %)\n", + "camera_0_progress (00:05:50): 906 / 919 seconds (98.6 %)\n", + "camera_2_progress (00:05:50): 905 / 918 seconds (98.6 %)\n", + "camera_1_progress (00:05:50): 905 / 918 seconds (98.6 %)\n", + "camera_3_progress (00:05:50): 905 / 918 seconds (98.6 %)\n", + "camera_1_progress (00:05:51): 908 / 918 seconds (98.9 %)\n", + "camera_3_progress (00:05:51): 908 / 918 seconds (98.9 %)\n", + "camera_0_progress (00:05:51): 909 / 919 seconds (98.9 %)\n", + "camera_2_progress (00:05:51): 908 / 918 seconds (98.9 %)\n", + "camera_0_progress (00:05:52): 913 / 919 seconds (99.3 %)\n", + "camera_2_progress (00:05:52): 912 / 918 seconds (99.3 %)\n", + "camera_1_progress (00:05:52): 912 / 918 seconds (99.3 %)\n", + "camera_3_progress (00:05:52): 912 / 918 seconds (99.3 %)\n", + "camera_3_progress (00:05:53): 914 / 918 seconds (99.6 %)\n", + "camera_0_progress (00:05:53): 915 / 919 seconds (99.6 %)\n", + "camera_2_progress (00:05:53): 915 / 918 seconds (99.7 %)\n", + "camera_1_progress (00:05:53): 915 / 918 seconds (99.7 %)\n", + "camera_0_progress (00:05:54): 918 / 919 seconds (99.9 %)\n", + "camera_2_progress (00:05:54): 917 / 918 seconds (99.9 %)\n", + "camera_1_progress (00:05:54): 917 / 918 seconds (99.9 %)\n", + "camera_3_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", + "camera_3_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", + "camera_2_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", + "camera_0_progress (00:05:54): 919 / 919 seconds (100.0 %)\n", + "camera_1_progress (00:05:54): 918 / 918 seconds (100.0 %)\n", + "Pipeline camera_2 finished.\n", + "Pipeline camera_0 finished.\n", + "Pipeline camera_3 finished.\n", + "Pipeline camera_1 finished.\n", + "All pipelines finished successfully.\n" + ] + } + ], + "source": [ + "pipelines = trace_config(cfg)\n", + "\n", + "for pipeline in pipelines:\n", + " pipeline.start()\n", + "for pipeline in pipelines:\n", + " pipeline.join()\n", + "\n", + "print(\"All pipelines finished successfully.\")" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "BagX", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.8.16" + }, + "orig_nbformat": 4 + }, + "nbformat": 4, + "nbformat_minor": 2 } diff --git a/docker/config/.p10k.zsh b/docker/config/.p10k.zsh index 4452a80..ca3f4aa 100755 --- a/docker/config/.p10k.zsh +++ b/docker/config/.p10k.zsh @@ -14,1647 +14,1648 @@ # Temporarily change options. 'builtin' 'local' '-a' 'p10k_config_opts' -[[ ! -o 'aliases' ]] || p10k_config_opts+=('aliases') -[[ ! -o 'sh_glob' ]] || p10k_config_opts+=('sh_glob') +[[ ! -o 'aliases' ]] || p10k_config_opts+=('aliases') +[[ ! -o 'sh_glob' ]] || p10k_config_opts+=('sh_glob') [[ ! -o 'no_brace_expand' ]] || p10k_config_opts+=('no_brace_expand') 'builtin' 'setopt' 'no_aliases' 'no_sh_glob' 'brace_expand' () { - emulate -L zsh -o extended_glob - - # Unset all configuration options. This allows you to apply configuration changes without - # restarting zsh. Edit ~/.p10k.zsh and type `source ~/.p10k.zsh`. - unset -m '(POWERLEVEL9K_*|DEFAULT_USER)~POWERLEVEL9K_GITSTATUS_DIR' - - # Zsh >= 5.1 is required. - [[ $ZSH_VERSION == (5.<1->*|<6->.*) ]] || return - - # The list of segments shown on the left. Fill it with the most important segments. - typeset -g POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=( - # =========================[ Line #1 ]========================= - # os_icon # os identifier - dir # current directory - vcs # git status - # =========================[ Line #2 ]========================= - newline # \n - prompt_char # prompt symbol - ) - - # The list of segments shown on the right. Fill it with less important segments. - # Right prompt on the last prompt line (where you are typing your commands) gets - # automatically hidden when the input line reaches it. Right prompt above the - # last prompt line gets hidden if it would overlap with left prompt. - typeset -g POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS=( - # =========================[ Line #1 ]========================= - status # exit code of the last command - command_execution_time # duration of the last command - background_jobs # presence of background jobs - direnv # direnv status (https://direnv.net/) - asdf # asdf version manager (https://github.com/asdf-vm/asdf) - virtualenv # python virtual environment (https://docs.python.org/3/library/venv.html) - anaconda # conda environment (https://conda.io/) - pyenv # python environment (https://github.com/pyenv/pyenv) - goenv # go environment (https://github.com/syndbg/goenv) - nodenv # node.js version from nodenv (https://github.com/nodenv/nodenv) - nvm # node.js version from nvm (https://github.com/nvm-sh/nvm) - nodeenv # node.js environment (https://github.com/ekalinin/nodeenv) - # node_version # node.js version - # go_version # go version (https://golang.org) - # rust_version # rustc version (https://www.rust-lang.org) - # dotnet_version # .NET version (https://dotnet.microsoft.com) - # php_version # php version (https://www.php.net/) - # laravel_version # laravel php framework version (https://laravel.com/) - # java_version # java version (https://www.java.com/) - # package # name@version from package.json (https://docs.npmjs.com/files/package.json) - rbenv # ruby version from rbenv (https://github.com/rbenv/rbenv) - rvm # ruby version from rvm (https://rvm.io) - fvm # flutter version management (https://github.com/leoafarias/fvm) - luaenv # lua version from luaenv (https://github.com/cehoffman/luaenv) - jenv # java version from jenv (https://github.com/jenv/jenv) - plenv # perl version from plenv (https://github.com/tokuhirom/plenv) - perlbrew # perl version from perlbrew (https://github.com/gugod/App-perlbrew) - phpenv # php version from phpenv (https://github.com/phpenv/phpenv) - scalaenv # scala version from scalaenv (https://github.com/scalaenv/scalaenv) - haskell_stack # haskell version from stack (https://haskellstack.org/) - kubecontext # current kubernetes context (https://kubernetes.io/) - terraform # terraform workspace (https://www.terraform.io) - # terraform_version # terraform version (https://www.terraform.io) - aws # aws profile (https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-profiles.html) - aws_eb_env # aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) - azure # azure account name (https://docs.microsoft.com/en-us/cli/azure) - gcloud # google cloud cli account and project (https://cloud.google.com/) - google_app_cred # google application credentials (https://cloud.google.com/docs/authentication/production) - toolbox # toolbox name (https://github.com/containers/toolbox) - context # user@hostname - nordvpn # nordvpn connection status, linux only (https://nordvpn.com/) - ranger # ranger shell (https://github.com/ranger/ranger) - nnn # nnn shell (https://github.com/jarun/nnn) - lf # lf shell (https://github.com/gokcehan/lf) - xplr # xplr shell (https://github.com/sayanarijit/xplr) - vim_shell # vim shell indicator (:sh) - midnight_commander # midnight commander shell (https://midnight-commander.org/) - nix_shell # nix shell (https://nixos.org/nixos/nix-pills/developing-with-nix-shell.html) - # vpn_ip # virtual private network indicator - # load # CPU load - # disk_usage # disk usage - # ram # free RAM - # swap # used swap - todo # todo items (https://github.com/todotxt/todo.txt-cli) - timewarrior # timewarrior tracking status (https://timewarrior.net/) - taskwarrior # taskwarrior task count (https://taskwarrior.org/) - # cpu_arch # CPU architecture - time # current time - # =========================[ Line #2 ]========================= - newline # \n - # ip # ip address and bandwidth usage for a specified network interface - # public_ip # public IP address - # proxy # system-wide http/https/ftp proxy - # battery # internal battery - # wifi # wifi speed - # example # example user-defined segment (see prompt_example function below) - ) - - # Defines character set used by powerlevel10k. It's best to let `p10k configure` set it for you. - typeset -g POWERLEVEL9K_MODE=compatible - # When set to `moderate`, some icons will have an extra space after them. This is meant to avoid - # icon overlap when using non-monospace fonts. When set to `none`, spaces are not added. - typeset -g POWERLEVEL9K_ICON_PADDING=none - - # Basic style options that define the overall look of your prompt. You probably don't want to - # change them. - typeset -g POWERLEVEL9K_BACKGROUND= # transparent background - typeset -g POWERLEVEL9K_{LEFT,RIGHT}_{LEFT,RIGHT}_WHITESPACE= # no surrounding whitespace - typeset -g POWERLEVEL9K_{LEFT,RIGHT}_SUBSEGMENT_SEPARATOR=' ' # separate segments with a space - typeset -g POWERLEVEL9K_{LEFT,RIGHT}_SEGMENT_SEPARATOR= # no end-of-line symbol - - # When set to true, icons appear before content on both sides of the prompt. When set - # to false, icons go after content. If empty or not set, icons go before content in the left - # prompt and after content in the right prompt. - # - # You can also override it for a specific segment: - # - # POWERLEVEL9K_STATUS_ICON_BEFORE_CONTENT=false - # - # Or for a specific segment in specific state: - # - # POWERLEVEL9K_DIR_NOT_WRITABLE_ICON_BEFORE_CONTENT=false - typeset -g POWERLEVEL9K_ICON_BEFORE_CONTENT=true - - # Add an empty line before each prompt. - typeset -g POWERLEVEL9K_PROMPT_ADD_NEWLINE=true - - # Connect left prompt lines with these symbols. - typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_PREFIX='%7F╭─' - typeset -g POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_PREFIX='%7F├─' - typeset -g POWERLEVEL9K_MULTILINE_LAST_PROMPT_PREFIX='%7F╰─' - # Connect right prompt lines with these symbols. - typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_SUFFIX='%7F─╮' - typeset -g POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_SUFFIX='%7F─┤' - typeset -g POWERLEVEL9K_MULTILINE_LAST_PROMPT_SUFFIX='%7F─╯' - - # The left end of left prompt. - typeset -g POWERLEVEL9K_LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL=' ' - # The right end of right prompt. - typeset -g POWERLEVEL9K_RIGHT_PROMPT_LAST_SEGMENT_END_SYMBOL=' ' - - # Ruler, a.k.a. the horizontal line before each prompt. If you set it to true, you'll - # probably want to set POWERLEVEL9K_PROMPT_ADD_NEWLINE=false above and - # POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR=' ' below. - typeset -g POWERLEVEL9K_SHOW_RULER=false - typeset -g POWERLEVEL9K_RULER_CHAR='─' # reasonable alternative: '·' - typeset -g POWERLEVEL9K_RULER_FOREGROUND=7 - - # Filler between left and right prompt on the first prompt line. You can set it to '·' or '─' - # to make it easier to see the alignment between left and right prompt and to separate prompt - # from command output. It serves the same purpose as ruler (see above) without increasing - # the number of prompt lines. You'll probably want to set POWERLEVEL9K_SHOW_RULER=false - # if using this. You might also like POWERLEVEL9K_PROMPT_ADD_NEWLINE=false for more compact - # prompt. - typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR='─' - if [[ $POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR != ' ' ]]; then - # The color of the filler. - typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_FOREGROUND=7 - # Add a space between the end of left prompt and the filler. - typeset -g POWERLEVEL9K_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL=' ' - # Add a space between the filler and the start of right prompt. - typeset -g POWERLEVEL9K_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL=' ' - # Start filler from the edge of the screen if there are no left segments on the first line. - typeset -g POWERLEVEL9K_EMPTY_LINE_LEFT_PROMPT_FIRST_SEGMENT_END_SYMBOL='%{%}' - # End filler on the edge of the screen if there are no right segments on the first line. - typeset -g POWERLEVEL9K_EMPTY_LINE_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL='%{%}' - fi - - #################################[ os_icon: os identifier ]################################## - # OS identifier color. - typeset -g POWERLEVEL9K_OS_ICON_FOREGROUND= - # Custom icon. - # typeset -g POWERLEVEL9K_OS_ICON_CONTENT_EXPANSION='⭐' - - ################################[ prompt_char: prompt symbol ]################################ - # Green prompt symbol if the last command succeeded. - typeset -g POWERLEVEL9K_PROMPT_CHAR_OK_{VIINS,VICMD,VIVIS,VIOWR}_FOREGROUND=2 - # Red prompt symbol if the last command failed. - typeset -g POWERLEVEL9K_PROMPT_CHAR_ERROR_{VIINS,VICMD,VIVIS,VIOWR}_FOREGROUND=1 - # Default prompt symbol. - typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIINS_CONTENT_EXPANSION='❯' - # Prompt symbol in command vi mode. - typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VICMD_CONTENT_EXPANSION='❮' - # Prompt symbol in visual vi mode. - typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIVIS_CONTENT_EXPANSION='V' - # Prompt symbol in overwrite vi mode. - typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIOWR_CONTENT_EXPANSION='▶' - typeset -g POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE=true - # No line terminator if prompt_char is the last segment. - typeset -g POWERLEVEL9K_PROMPT_CHAR_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL='' - # No line introducer if prompt_char is the first segment. - typeset -g POWERLEVEL9K_PROMPT_CHAR_LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL= - - ##################################[ dir: current directory ]################################## - # Default current directory color. - typeset -g POWERLEVEL9K_DIR_FOREGROUND=4 - # If directory is too long, shorten some of its segments to the shortest possible unique - # prefix. The shortened directory can be tab-completed to the original. - typeset -g POWERLEVEL9K_SHORTEN_STRATEGY=truncate_to_unique - # Replace removed segment suffixes with this symbol. - typeset -g POWERLEVEL9K_SHORTEN_DELIMITER= - # Color of the shortened directory segments. - typeset -g POWERLEVEL9K_DIR_SHORTENED_FOREGROUND=4 - # Color of the anchor directory segments. Anchor segments are never shortened. The first - # segment is always an anchor. - typeset -g POWERLEVEL9K_DIR_ANCHOR_FOREGROUND=4 - # Set to true to display anchor directory segments in bold. - typeset -g POWERLEVEL9K_DIR_ANCHOR_BOLD=false - # Don't shorten directories that contain any of these files. They are anchors. - local anchor_files=( - .bzr - .citc - .git - .hg - .node-version - .python-version - .go-version - .ruby-version - .lua-version - .java-version - .perl-version - .php-version - .tool-version - .shorten_folder_marker - .svn - .terraform - CVS - Cargo.toml - composer.json - go.mod - package.json - stack.yaml - ) - typeset -g POWERLEVEL9K_SHORTEN_FOLDER_MARKER="(${(j:|:)anchor_files})" - # If set to "first" ("last"), remove everything before the first (last) subdirectory that contains - # files matching $POWERLEVEL9K_SHORTEN_FOLDER_MARKER. For example, when the current directory is - # /foo/bar/git_repo/nested_git_repo/baz, prompt will display git_repo/nested_git_repo/baz (first) - # or nested_git_repo/baz (last). This assumes that git_repo and nested_git_repo contain markers - # and other directories don't. - # - # Optionally, "first" and "last" can be followed by ":" where is an integer. - # This moves the truncation point to the right (positive offset) or to the left (negative offset) - # relative to the marker. Plain "first" and "last" are equivalent to "first:0" and "last:0" - # respectively. - typeset -g POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER=false - # Don't shorten this many last directory segments. They are anchors. - typeset -g POWERLEVEL9K_SHORTEN_DIR_LENGTH=1 - # Shorten directory if it's longer than this even if there is space for it. The value can - # be either absolute (e.g., '80') or a percentage of terminal width (e.g, '50%'). If empty, - # directory will be shortened only when prompt doesn't fit or when other parameters demand it - # (see POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS and POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT below). - # If set to `0`, directory will always be shortened to its minimum length. - typeset -g POWERLEVEL9K_DIR_MAX_LENGTH=80 - # When `dir` segment is on the last prompt line, try to shorten it enough to leave at least this - # many columns for typing commands. - typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS=40 - # When `dir` segment is on the last prompt line, try to shorten it enough to leave at least - # COLUMNS * POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT * 0.01 columns for typing commands. - typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT=50 - # If set to true, embed a hyperlink into the directory. Useful for quickly - # opening a directory in the file manager simply by clicking the link. - # Can also be handy when the directory is shortened, as it allows you to see - # the full directory that was used in previous commands. - typeset -g POWERLEVEL9K_DIR_HYPERLINK=false - - # Enable special styling for non-writable directories. See POWERLEVEL9K_LOCK_ICON and - # POWERLEVEL9K_DIR_CLASSES below. - typeset -g POWERLEVEL9K_DIR_SHOW_WRITABLE=v2 - - # Enable special styling for non-writable and non-existent directories. See POWERLEVEL9K_LOCK_ICON - # and POWERLEVEL9K_DIR_CLASSES below. - typeset -g POWERLEVEL9K_DIR_SHOW_WRITABLE=v3 - - # The default icon shown next to non-writable and non-existent directories when - # POWERLEVEL9K_DIR_SHOW_WRITABLE is set to v3. - typeset -g POWERLEVEL9K_LOCK_ICON='∅' - - # POWERLEVEL9K_DIR_CLASSES allows you to specify custom icons and colors for different - # directories. It must be an array with 3 * N elements. Each triplet consists of: - # - # 1. A pattern against which the current directory ($PWD) is matched. Matching is done with - # extended_glob option enabled. - # 2. Directory class for the purpose of styling. - # 3. An empty string. - # - # Triplets are tried in order. The first triplet whose pattern matches $PWD wins. - # - # If POWERLEVEL9K_DIR_SHOW_WRITABLE is set to v3, non-writable and non-existent directories - # acquire class suffix _NOT_WRITABLE and NON_EXISTENT respectively. - # - # For example, given these settings: - # - # typeset -g POWERLEVEL9K_DIR_CLASSES=( - # '~/work(|/*)' WORK '' - # '~(|/*)' HOME '' - # '*' DEFAULT '') - # - # Whenever the current directory is ~/work or a subdirectory of ~/work, it gets styled with one - # of the following classes depending on its writability and existence: WORK, WORK_NOT_WRITABLE or - # WORK_NON_EXISTENT. - # - # Simply assigning classes to directories doesn't have any visible effects. It merely gives you an - # option to define custom colors and icons for different directory classes. - # - # # Styling for WORK. - # typeset -g POWERLEVEL9K_DIR_WORK_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_DIR_WORK_FOREGROUND=4 - # typeset -g POWERLEVEL9K_DIR_WORK_SHORTENED_FOREGROUND=4 - # typeset -g POWERLEVEL9K_DIR_WORK_ANCHOR_FOREGROUND=4 - # - # # Styling for WORK_NOT_WRITABLE. - # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_FOREGROUND=4 - # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_SHORTENED_FOREGROUND=4 - # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_ANCHOR_FOREGROUND=4# - # - # Styling for WORK_NON_EXISTENT. - # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_FOREGROUND=4 - # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_SHORTENED_FOREGROUND=4 - # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_ANCHOR_FOREGROUND=4 - # - # If a styling parameter isn't explicitly defined for some class, it falls back to the classless - # parameter. For example, if POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_FOREGROUND is not set, it falls - # back to POWERLEVEL9K_DIR_FOREGROUND. - # - typeset -g POWERLEVEL9K_DIR_CLASSES=() - - # Custom prefix. - # typeset -g POWERLEVEL9K_DIR_PREFIX='%fin ' - - #####################################[ vcs: git status ]###################################### - # Branch icon. Set this parameter to '\UE0A0 ' for the popular Powerline branch icon. - typeset -g POWERLEVEL9K_VCS_BRANCH_ICON= - - # Untracked files icon. It's really a question mark, your font isn't broken. - # Change the value of this parameter to show a different icon. - typeset -g POWERLEVEL9K_VCS_UNTRACKED_ICON='?' - - # Formatter for Git status. - # - # Example output: master wip ⇣42⇡42 *42 merge ~42 +42 !42 ?42. - # - # You can edit the function to customize how Git status looks. - # - # VCS_STATUS_* parameters are set by gitstatus plugin. See reference: - # https://github.com/romkatv/gitstatus/blob/master/gitstatus.plugin.zsh. - function my_git_formatter() { - emulate -L zsh - - if [[ -n $P9K_CONTENT ]]; then - # If P9K_CONTENT is not empty, use it. It's either "loading" or from vcs_info (not from - # gitstatus plugin). VCS_STATUS_* parameters are not available in this case. - typeset -g my_git_format=$P9K_CONTENT - return - fi - - if (( $1 )); then - # Styling for up-to-date Git status. - local meta='%f' # default foreground - local clean='%2F' # green foreground - local modified='%3F' # yellow foreground - local untracked='%4F' # blue foreground - local conflicted='%1F' # red foreground - else - # Styling for incomplete and stale Git status. - local meta='%f' # default foreground - local clean='%f' # default foreground - local modified='%f' # default foreground - local untracked='%f' # default foreground - local conflicted='%f' # default foreground - fi - - local res - - if [[ -n $VCS_STATUS_LOCAL_BRANCH ]]; then - local branch=${(V)VCS_STATUS_LOCAL_BRANCH} - # If local branch name is at most 32 characters long, show it in full. - # Otherwise show the first 12 … the last 12. - # Tip: To always show local branch name in full without truncation, delete the next line. - (( $#branch > 32 )) && branch[13,-13]="…" # <-- this line - res+="${clean}${(g::)POWERLEVEL9K_VCS_BRANCH_ICON}${branch//\%/%%}" - fi - - if [[ -n $VCS_STATUS_TAG - # Show tag only if not on a branch. - # Tip: To always show tag, delete the next line. - && -z $VCS_STATUS_LOCAL_BRANCH # <-- this line - ]]; then - local tag=${(V)VCS_STATUS_TAG} - # If tag name is at most 32 characters long, show it in full. - # Otherwise show the first 12 … the last 12. - # Tip: To always show tag name in full without truncation, delete the next line. - (( $#tag > 32 )) && tag[13,-13]="…" # <-- this line - res+="${meta}#${clean}${tag//\%/%%}" - fi - - # Display the current Git commit if there is no branch and no tag. - # Tip: To always display the current Git commit, delete the next line. - [[ -z $VCS_STATUS_LOCAL_BRANCH && -z $VCS_STATUS_TAG ]] && # <-- this line - res+="${meta}@${clean}${VCS_STATUS_COMMIT[1,8]}" - - # Show tracking branch name if it differs from local branch. - if [[ -n ${VCS_STATUS_REMOTE_BRANCH:#$VCS_STATUS_LOCAL_BRANCH} ]]; then - res+="${meta}:${clean}${(V)VCS_STATUS_REMOTE_BRANCH//\%/%%}" - fi - - # Display "wip" if the latest commit's summary contains "wip" or "WIP". - if [[ $VCS_STATUS_COMMIT_SUMMARY == (|*[^[:alnum:]])(wip|WIP)(|[^[:alnum:]]*) ]]; then - res+=" ${modified}wip" - fi - - # ⇣42 if behind the remote. - (( VCS_STATUS_COMMITS_BEHIND )) && res+=" ${clean}⇣${VCS_STATUS_COMMITS_BEHIND}" - # ⇡42 if ahead of the remote; no leading space if also behind the remote: ⇣42⇡42. - (( VCS_STATUS_COMMITS_AHEAD && !VCS_STATUS_COMMITS_BEHIND )) && res+=" " - (( VCS_STATUS_COMMITS_AHEAD )) && res+="${clean}⇡${VCS_STATUS_COMMITS_AHEAD}" - # ⇠42 if behind the push remote. - (( VCS_STATUS_PUSH_COMMITS_BEHIND )) && res+=" ${clean}⇠${VCS_STATUS_PUSH_COMMITS_BEHIND}" - (( VCS_STATUS_PUSH_COMMITS_AHEAD && !VCS_STATUS_PUSH_COMMITS_BEHIND )) && res+=" " - # ⇢42 if ahead of the push remote; no leading space if also behind: ⇠42⇢42. - (( VCS_STATUS_PUSH_COMMITS_AHEAD )) && res+="${clean}⇢${VCS_STATUS_PUSH_COMMITS_AHEAD}" - # *42 if have stashes. - (( VCS_STATUS_STASHES )) && res+=" ${clean}*${VCS_STATUS_STASHES}" - # 'merge' if the repo is in an unusual state. - [[ -n $VCS_STATUS_ACTION ]] && res+=" ${conflicted}${VCS_STATUS_ACTION}" - # ~42 if have merge conflicts. - (( VCS_STATUS_NUM_CONFLICTED )) && res+=" ${conflicted}~${VCS_STATUS_NUM_CONFLICTED}" - # +42 if have staged changes. - (( VCS_STATUS_NUM_STAGED )) && res+=" ${modified}+${VCS_STATUS_NUM_STAGED}" - # !42 if have unstaged changes. - (( VCS_STATUS_NUM_UNSTAGED )) && res+=" ${modified}!${VCS_STATUS_NUM_UNSTAGED}" - # ?42 if have untracked files. It's really a question mark, your font isn't broken. - # See POWERLEVEL9K_VCS_UNTRACKED_ICON above if you want to use a different icon. - # Remove the next line if you don't want to see untracked files at all. - (( VCS_STATUS_NUM_UNTRACKED )) && res+=" ${untracked}${(g::)POWERLEVEL9K_VCS_UNTRACKED_ICON}${VCS_STATUS_NUM_UNTRACKED}" - # "─" if the number of unstaged files is unknown. This can happen due to - # POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY (see below) being set to a non-negative number lower - # than the number of files in the Git index, or due to bash.showDirtyState being set to false - # in the repository config. The number of staged and untracked files may also be unknown - # in this case. - (( VCS_STATUS_HAS_UNSTAGED == -1 )) && res+=" ${modified}─" - - typeset -g my_git_format=$res - } - functions -M my_git_formatter 2>/dev/null - - # Don't count the number of unstaged, untracked and conflicted files in Git repositories with - # more than this many files in the index. Negative value means infinity. - # - # If you are working in Git repositories with tens of millions of files and seeing performance - # sagging, try setting POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY to a number lower than the output - # of `git ls-files | wc -l`. Alternatively, add `bash.showDirtyState = false` to the repository's - # config: `git config bash.showDirtyState false`. - typeset -g POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY=-1 - - # Don't show Git status in prompt for repositories whose workdir matches this pattern. - # For example, if set to '~', the Git repository at $HOME/.git will be ignored. - # Multiple patterns can be combined with '|': '~(|/foo)|/bar/baz/*'. - typeset -g POWERLEVEL9K_VCS_DISABLED_WORKDIR_PATTERN='~' - - # Disable the default Git status formatting. - typeset -g POWERLEVEL9K_VCS_DISABLE_GITSTATUS_FORMATTING=true - # Install our own Git status formatter. - typeset -g POWERLEVEL9K_VCS_CONTENT_EXPANSION='${$((my_git_formatter(1)))+${my_git_format}}' - typeset -g POWERLEVEL9K_VCS_LOADING_CONTENT_EXPANSION='${$((my_git_formatter(0)))+${my_git_format}}' - # Enable counters for staged, unstaged, etc. - typeset -g POWERLEVEL9K_VCS_{STAGED,UNSTAGED,UNTRACKED,CONFLICTED,COMMITS_AHEAD,COMMITS_BEHIND}_MAX_NUM=-1 - - # Icon color. - typeset -g POWERLEVEL9K_VCS_VISUAL_IDENTIFIER_COLOR=2 - typeset -g POWERLEVEL9K_VCS_LOADING_VISUAL_IDENTIFIER_COLOR= - # Custom icon. - typeset -g POWERLEVEL9K_VCS_VISUAL_IDENTIFIER_EXPANSION= - # Custom prefix. - typeset -g POWERLEVEL9K_VCS_PREFIX='%fon ' - - # Show status of repositories of these types. You can add svn and/or hg if you are - # using them. If you do, your prompt may become slow even when your current directory - # isn't in an svn or hg repository. - typeset -g POWERLEVEL9K_VCS_BACKENDS=(git) - - # These settings are used for repositories other than Git or when gitstatusd fails and - # Powerlevel10k has to fall back to using vcs_info. - typeset -g POWERLEVEL9K_VCS_CLEAN_FOREGROUND=2 - typeset -g POWERLEVEL9K_VCS_UNTRACKED_FOREGROUND=2 - typeset -g POWERLEVEL9K_VCS_MODIFIED_FOREGROUND=3 - - ##########################[ status: exit code of the last command ]########################### - # Enable OK_PIPE, ERROR_PIPE and ERROR_SIGNAL status states to allow us to enable, disable and - # style them independently from the regular OK and ERROR state. - typeset -g POWERLEVEL9K_STATUS_EXTENDED_STATES=true - - # Status on success. No content, just an icon. No need to show it if prompt_char is enabled as - # it will signify success by turning green. - typeset -g POWERLEVEL9K_STATUS_OK=false - typeset -g POWERLEVEL9K_STATUS_OK_FOREGROUND=2 - typeset -g POWERLEVEL9K_STATUS_OK_VISUAL_IDENTIFIER_EXPANSION='✔' - - # Status when some part of a pipe command fails but the overall exit status is zero. It may look - # like this: 1|0. - typeset -g POWERLEVEL9K_STATUS_OK_PIPE=true - typeset -g POWERLEVEL9K_STATUS_OK_PIPE_FOREGROUND=2 - typeset -g POWERLEVEL9K_STATUS_OK_PIPE_VISUAL_IDENTIFIER_EXPANSION='✔' - - # Status when it's just an error code (e.g., '1'). No need to show it if prompt_char is enabled as - # it will signify error by turning red. - typeset -g POWERLEVEL9K_STATUS_ERROR=false - typeset -g POWERLEVEL9K_STATUS_ERROR_FOREGROUND=1 - typeset -g POWERLEVEL9K_STATUS_ERROR_VISUAL_IDENTIFIER_EXPANSION='х' - - # Status when the last command was terminated by a signal. - typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL=true - typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL_FOREGROUND=1 - # Use terse signal names: "INT" instead of "SIGINT(2)". - typeset -g POWERLEVEL9K_STATUS_VERBOSE_SIGNAME=false - typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL_VISUAL_IDENTIFIER_EXPANSION='х' - - # Status when some part of a pipe command fails and the overall exit status is also non-zero. - # It may look like this: 1|0. - typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE=true - typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE_FOREGROUND=1 - typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE_VISUAL_IDENTIFIER_EXPANSION='х' - - ###################[ command_execution_time: duration of the last command ]################### - # Show duration of the last command if takes at least this many seconds. - typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=3 - # Show this many fractional digits. Zero means round to seconds. - typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=0 - # Execution time color. - typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FOREGROUND=3 - # Duration format: 1d 2h 3m 4s. - typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FORMAT='d h m s' - # Custom icon. - typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_VISUAL_IDENTIFIER_EXPANSION= - # Custom prefix. - typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_PREFIX='%ftook ' - - #######################[ background_jobs: presence of background jobs ]####################### - # Don't show the number of background jobs. - typeset -g POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE=false - # Background jobs color. - typeset -g POWERLEVEL9K_BACKGROUND_JOBS_FOREGROUND=1 - # Custom icon. - typeset -g POWERLEVEL9K_BACKGROUND_JOBS_VISUAL_IDENTIFIER_EXPANSION='≡' - - #######################[ direnv: direnv status (https://direnv.net/) ]######################## - # Direnv color. - typeset -g POWERLEVEL9K_DIRENV_FOREGROUND=3 - # Custom icon. - # typeset -g POWERLEVEL9K_DIRENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###############[ asdf: asdf version manager (https://github.com/asdf-vm/asdf) ]############### - # Default asdf color. Only used to display tools for which there is no color override (see below). - # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_FOREGROUND. - typeset -g POWERLEVEL9K_ASDF_FOREGROUND=6 - - # There are four parameters that can be used to hide asdf tools. Each parameter describes - # conditions under which a tool gets hidden. Parameters can hide tools but not unhide them. If at - # least one parameter decides to hide a tool, that tool gets hidden. If no parameter decides to - # hide a tool, it gets shown. - # - # Special note on the difference between POWERLEVEL9K_ASDF_SOURCES and - # POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW. Consider the effect of the following commands: - # - # asdf local python 3.8.1 - # asdf global python 3.8.1 - # - # After running both commands the current python version is 3.8.1 and its source is "local" as - # it takes precedence over "global". If POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW is set to false, - # it'll hide python version in this case because 3.8.1 is the same as the global version. - # POWERLEVEL9K_ASDF_SOURCES will hide python version only if the value of this parameter doesn't - # contain "local". - - # Hide tool versions that don't come from one of these sources. - # - # Available sources: - # - # - shell `asdf current` says "set by ASDF_${TOOL}_VERSION environment variable" - # - local `asdf current` says "set by /some/not/home/directory/file" - # - global `asdf current` says "set by /home/username/file" - # - # Note: If this parameter is set to (shell local global), it won't hide tools. - # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SOURCES. - typeset -g POWERLEVEL9K_ASDF_SOURCES=(shell local global) - - # If set to false, hide tool versions that are the same as global. - # - # Note: The name of this parameter doesn't reflect its meaning at all. - # Note: If this parameter is set to true, it won't hide tools. - # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_PROMPT_ALWAYS_SHOW. - typeset -g POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW=false - - # If set to false, hide tool versions that are equal to "system". - # - # Note: If this parameter is set to true, it won't hide tools. - # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SHOW_SYSTEM. - typeset -g POWERLEVEL9K_ASDF_SHOW_SYSTEM=true - - # If set to non-empty value, hide tools unless there is a file matching the specified file pattern - # in the current directory, or its parent directory, or its grandparent directory, and so on. - # - # Note: If this parameter is set to empty value, it won't hide tools. - # Note: SHOW_ON_UPGLOB isn't specific to asdf. It works with all prompt segments. - # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SHOW_ON_UPGLOB. - # - # Example: Hide nodejs version when there is no package.json and no *.js files in the current - # directory, in `..`, in `../..` and so on. - # - # typeset -g POWERLEVEL9K_ASDF_NODEJS_SHOW_ON_UPGLOB='*.js|package.json' - typeset -g POWERLEVEL9K_ASDF_SHOW_ON_UPGLOB= - - # Ruby version from asdf. - typeset -g POWERLEVEL9K_ASDF_RUBY_FOREGROUND=1 - # typeset -g POWERLEVEL9K_ASDF_RUBY_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_RUBY_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Python version from asdf. - typeset -g POWERLEVEL9K_ASDF_PYTHON_FOREGROUND=6 - # typeset -g POWERLEVEL9K_ASDF_PYTHON_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_PYTHON_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Go version from asdf. - typeset -g POWERLEVEL9K_ASDF_GOLANG_FOREGROUND=6 - # typeset -g POWERLEVEL9K_ASDF_GOLANG_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_GOLANG_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Node.js version from asdf. - typeset -g POWERLEVEL9K_ASDF_NODEJS_FOREGROUND=2 - # typeset -g POWERLEVEL9K_ASDF_NODEJS_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_NODEJS_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Rust version from asdf. - typeset -g POWERLEVEL9K_ASDF_RUST_FOREGROUND=4 - # typeset -g POWERLEVEL9K_ASDF_RUST_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_RUST_SHOW_ON_UPGLOB='*.foo|*.bar' - - # .NET Core version from asdf. - typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_FOREGROUND=5 - # typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Flutter version from asdf. - typeset -g POWERLEVEL9K_ASDF_FLUTTER_FOREGROUND=4 - # typeset -g POWERLEVEL9K_ASDF_FLUTTER_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_FLUTTER_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Lua version from asdf. - typeset -g POWERLEVEL9K_ASDF_LUA_FOREGROUND=4 - # typeset -g POWERLEVEL9K_ASDF_LUA_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_LUA_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Java version from asdf. - typeset -g POWERLEVEL9K_ASDF_JAVA_FOREGROUND=4 - # typeset -g POWERLEVEL9K_ASDF_JAVA_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_JAVA_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Perl version from asdf. - typeset -g POWERLEVEL9K_ASDF_PERL_FOREGROUND=6 - # typeset -g POWERLEVEL9K_ASDF_PERL_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_PERL_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Erlang version from asdf. - typeset -g POWERLEVEL9K_ASDF_ERLANG_FOREGROUND=1 - # typeset -g POWERLEVEL9K_ASDF_ERLANG_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_ERLANG_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Elixir version from asdf. - typeset -g POWERLEVEL9K_ASDF_ELIXIR_FOREGROUND=5 - # typeset -g POWERLEVEL9K_ASDF_ELIXIR_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_ELIXIR_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Postgres version from asdf. - typeset -g POWERLEVEL9K_ASDF_POSTGRES_FOREGROUND=6 - # typeset -g POWERLEVEL9K_ASDF_POSTGRES_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_POSTGRES_SHOW_ON_UPGLOB='*.foo|*.bar' - - # PHP version from asdf. - typeset -g POWERLEVEL9K_ASDF_PHP_FOREGROUND=5 - # typeset -g POWERLEVEL9K_ASDF_PHP_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_PHP_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Haskell version from asdf. - typeset -g POWERLEVEL9K_ASDF_HASKELL_FOREGROUND=3 - # typeset -g POWERLEVEL9K_ASDF_HASKELL_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_HASKELL_SHOW_ON_UPGLOB='*.foo|*.bar' - - # Julia version from asdf. - typeset -g POWERLEVEL9K_ASDF_JULIA_FOREGROUND=2 - # typeset -g POWERLEVEL9K_ASDF_JULIA_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_ASDF_JULIA_SHOW_ON_UPGLOB='*.foo|*.bar' - - ##########[ nordvpn: nordvpn connection status, linux only (https://nordvpn.com/) ]########### - # NordVPN connection indicator color. - typeset -g POWERLEVEL9K_NORDVPN_FOREGROUND=6 - # Hide NordVPN connection indicator when not connected. - typeset -g POWERLEVEL9K_NORDVPN_{DISCONNECTED,CONNECTING,DISCONNECTING}_CONTENT_EXPANSION= - typeset -g POWERLEVEL9K_NORDVPN_{DISCONNECTED,CONNECTING,DISCONNECTING}_VISUAL_IDENTIFIER_EXPANSION= - # Custom icon. - typeset -g POWERLEVEL9K_NORDVPN_VISUAL_IDENTIFIER_EXPANSION='nord' - - #################[ ranger: ranger shell (https://github.com/ranger/ranger) ]################## - # Ranger shell color. - typeset -g POWERLEVEL9K_RANGER_FOREGROUND=3 - # Custom icon. - typeset -g POWERLEVEL9K_RANGER_VISUAL_IDENTIFIER_EXPANSION='▲' - - ######################[ nnn: nnn shell (https://github.com/jarun/nnn) ]####################### - # Nnn shell color. - typeset -g POWERLEVEL9K_NNN_FOREGROUND=3 - # Custom icon. - # typeset -g POWERLEVEL9K_NNN_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ######################[ lf: lf shell (https://github.com/gokcehan/lf) ]####################### - # lf shell color. - typeset -g POWERLEVEL9K_LF_FOREGROUND=3 - # Custom icon. - # typeset -g POWERLEVEL9K_LF_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##################[ xplr: xplr shell (https://github.com/sayanarijit/xplr) ]################## - # xplr shell color. - typeset -g POWERLEVEL9K_XPLR_FOREGROUND=3 - # Custom icon. - # typeset -g POWERLEVEL9K_XPLR_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###########################[ vim_shell: vim shell indicator (:sh) ]########################### - # Vim shell indicator color. - typeset -g POWERLEVEL9K_VIM_SHELL_FOREGROUND=3 - # Custom icon. - # typeset -g POWERLEVEL9K_VIM_SHELL_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ######[ midnight_commander: midnight commander shell (https://midnight-commander.org/) ]###### - # Midnight Commander shell color. - typeset -g POWERLEVEL9K_MIDNIGHT_COMMANDER_FOREGROUND=3 - # Custom icon. - # typeset -g POWERLEVEL9K_MIDNIGHT_COMMANDER_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #[ nix_shell: nix shell (https://nixos.org/nixos/nix-pills/developing-with-nix-shell.html) ]## - # Nix shell color. - typeset -g POWERLEVEL9K_NIX_SHELL_FOREGROUND=4 - - # Display the icon of nix_shell if PATH contains a subdirectory of /nix/store. - # typeset -g POWERLEVEL9K_NIX_SHELL_INFER_FROM_PATH=false - - # Tip: If you want to see just the icon without "pure" and "impure", uncomment the next line. - # typeset -g POWERLEVEL9K_NIX_SHELL_CONTENT_EXPANSION= - - # Custom icon. - # typeset -g POWERLEVEL9K_NIX_SHELL_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##################################[ disk_usage: disk usage ]################################## - # Colors for different levels of disk usage. - typeset -g POWERLEVEL9K_DISK_USAGE_NORMAL_FOREGROUND=2 - typeset -g POWERLEVEL9K_DISK_USAGE_WARNING_FOREGROUND=3 - typeset -g POWERLEVEL9K_DISK_USAGE_CRITICAL_FOREGROUND=1 - # Thresholds for different levels of disk usage (percentage points). - typeset -g POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL=90 - typeset -g POWERLEVEL9K_DISK_USAGE_CRITICAL_LEVEL=95 - # If set to true, hide disk usage when below $POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL percent. - typeset -g POWERLEVEL9K_DISK_USAGE_ONLY_WARNING=false - # Custom icon. - # typeset -g POWERLEVEL9K_DISK_USAGE_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ######################################[ ram: free RAM ]####################################### - # RAM color. - typeset -g POWERLEVEL9K_RAM_FOREGROUND=2 - # Custom icon. - # typeset -g POWERLEVEL9K_RAM_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #####################################[ swap: used swap ]###################################### - # Swap color. - typeset -g POWERLEVEL9K_SWAP_FOREGROUND=3 - # Custom icon. - # typeset -g POWERLEVEL9K_SWAP_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ######################################[ load: CPU load ]###################################### - # Show average CPU load over this many last minutes. Valid values are 1, 5 and 15. - typeset -g POWERLEVEL9K_LOAD_WHICH=5 - # Load color when load is under 50%. - typeset -g POWERLEVEL9K_LOAD_NORMAL_FOREGROUND=2 - # Load color when load is between 50% and 70%. - typeset -g POWERLEVEL9K_LOAD_WARNING_FOREGROUND=3 - # Load color when load is over 70%. - typeset -g POWERLEVEL9K_LOAD_CRITICAL_FOREGROUND=1 - # Custom icon. - # typeset -g POWERLEVEL9K_LOAD_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ################[ todo: todo items (https://github.com/todotxt/todo.txt-cli) ]################ - # Todo color. - typeset -g POWERLEVEL9K_TODO_FOREGROUND=4 - # Hide todo when the total number of tasks is zero. - typeset -g POWERLEVEL9K_TODO_HIDE_ZERO_TOTAL=true - # Hide todo when the number of tasks after filtering is zero. - typeset -g POWERLEVEL9K_TODO_HIDE_ZERO_FILTERED=false - - # Todo format. The following parameters are available within the expansion. - # - # - P9K_TODO_TOTAL_TASK_COUNT The total number of tasks. - # - P9K_TODO_FILTERED_TASK_COUNT The number of tasks after filtering. - # - # These variables correspond to the last line of the output of `todo.sh -p ls`: - # - # TODO: 24 of 42 tasks shown - # - # Here 24 is P9K_TODO_FILTERED_TASK_COUNT and 42 is P9K_TODO_TOTAL_TASK_COUNT. - # - # typeset -g POWERLEVEL9K_TODO_CONTENT_EXPANSION='$P9K_TODO_FILTERED_TASK_COUNT' - - # Custom icon. - # typeset -g POWERLEVEL9K_TODO_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###########[ timewarrior: timewarrior tracking status (https://timewarrior.net/) ]############ - # Timewarrior color. - typeset -g POWERLEVEL9K_TIMEWARRIOR_FOREGROUND=4 - # If the tracked task is longer than 24 characters, truncate and append "…". - # Tip: To always display tasks without truncation, delete the following parameter. - # Tip: To hide task names and display just the icon when time tracking is enabled, set the - # value of the following parameter to "". - typeset -g POWERLEVEL9K_TIMEWARRIOR_CONTENT_EXPANSION='${P9K_CONTENT:0:24}${${P9K_CONTENT:24}:+…}' - - # Custom icon. - # typeset -g POWERLEVEL9K_TIMEWARRIOR_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##############[ taskwarrior: taskwarrior task count (https://taskwarrior.org/) ]############## - # Taskwarrior color. - typeset -g POWERLEVEL9K_TASKWARRIOR_FOREGROUND=6 - - # Taskwarrior segment format. The following parameters are available within the expansion. - # - # - P9K_TASKWARRIOR_PENDING_COUNT The number of pending tasks: `task +PENDING count`. - # - P9K_TASKWARRIOR_OVERDUE_COUNT The number of overdue tasks: `task +OVERDUE count`. - # - # Zero values are represented as empty parameters. - # - # The default format: - # - # '${P9K_TASKWARRIOR_OVERDUE_COUNT:+"!$P9K_TASKWARRIOR_OVERDUE_COUNT/"}$P9K_TASKWARRIOR_PENDING_COUNT' - # - # typeset -g POWERLEVEL9K_TASKWARRIOR_CONTENT_EXPANSION='$P9K_TASKWARRIOR_PENDING_COUNT' - - # Custom icon. - # typeset -g POWERLEVEL9K_TASKWARRIOR_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ################################[ cpu_arch: CPU architecture ]################################ - # CPU architecture color. - typeset -g POWERLEVEL9K_CPU_ARCH_FOREGROUND=3 - - # Hide the segment when on a specific CPU architecture. - # typeset -g POWERLEVEL9K_CPU_ARCH_X86_64_CONTENT_EXPANSION= - # typeset -g POWERLEVEL9K_CPU_ARCH_X86_64_VISUAL_IDENTIFIER_EXPANSION= - - # Custom icon. - # typeset -g POWERLEVEL9K_CPU_ARCH_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##################################[ context: user@hostname ]################################## - # Context color when running with privileges. - typeset -g POWERLEVEL9K_CONTEXT_ROOT_FOREGROUND=1 - # Context color in SSH without privileges. - typeset -g POWERLEVEL9K_CONTEXT_{REMOTE,REMOTE_SUDO}_FOREGROUND=7 - # Default context color (no privileges, no SSH). - typeset -g POWERLEVEL9K_CONTEXT_FOREGROUND=7 - - # Context format when running with privileges: bold user@hostname. - typeset -g POWERLEVEL9K_CONTEXT_ROOT_TEMPLATE='%B%n@%m' - # Context format when in SSH without privileges: user@hostname. - typeset -g POWERLEVEL9K_CONTEXT_{REMOTE,REMOTE_SUDO}_TEMPLATE='%n@%m' - # Default context format (no privileges, no SSH): user@hostname. - typeset -g POWERLEVEL9K_CONTEXT_TEMPLATE='%n@%m' - - # Don't show context unless running with privileges or in SSH. - # Tip: Remove the next line to always show context. - typeset -g POWERLEVEL9K_CONTEXT_{DEFAULT,SUDO}_{CONTENT,VISUAL_IDENTIFIER}_EXPANSION= - - # Custom icon. - # typeset -g POWERLEVEL9K_CONTEXT_VISUAL_IDENTIFIER_EXPANSION='⭐' - # Custom prefix. - typeset -g POWERLEVEL9K_CONTEXT_PREFIX='%fwith ' - - ###[ virtualenv: python virtual environment (https://docs.python.org/3/library/venv.html) ]### - # Python virtual environment color. - typeset -g POWERLEVEL9K_VIRTUALENV_FOREGROUND=6 - # Don't show Python version next to the virtual environment name. - typeset -g POWERLEVEL9K_VIRTUALENV_SHOW_PYTHON_VERSION=false - # If set to "false", won't show virtualenv if pyenv is already shown. - # If set to "if-different", won't show virtualenv if it's the same as pyenv. - typeset -g POWERLEVEL9K_VIRTUALENV_SHOW_WITH_PYENV=false - # Separate environment name from Python version only with a space. - typeset -g POWERLEVEL9K_VIRTUALENV_{LEFT,RIGHT}_DELIMITER= - # Custom icon. - # typeset -g POWERLEVEL9K_VIRTUALENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #####################[ anaconda: conda environment (https://conda.io/) ]###################### - # Anaconda environment color. - typeset -g POWERLEVEL9K_ANACONDA_FOREGROUND=6 - - # Anaconda segment format. The following parameters are available within the expansion. - # - # - CONDA_PREFIX Absolute path to the active Anaconda/Miniconda environment. - # - CONDA_DEFAULT_ENV Name of the active Anaconda/Miniconda environment. - # - CONDA_PROMPT_MODIFIER Configurable prompt modifier (see below). - # - P9K_ANACONDA_PYTHON_VERSION Current python version (python --version). - # - # CONDA_PROMPT_MODIFIER can be configured with the following command: - # - # conda config --set env_prompt '({default_env}) ' - # - # The last argument is a Python format string that can use the following variables: - # - # - prefix The same as CONDA_PREFIX. - # - default_env The same as CONDA_DEFAULT_ENV. - # - name The last segment of CONDA_PREFIX. - # - stacked_env Comma-separated list of names in the environment stack. The first element is - # always the same as default_env. - # - # Note: '({default_env}) ' is the default value of env_prompt. - # - # The default value of POWERLEVEL9K_ANACONDA_CONTENT_EXPANSION expands to $CONDA_PROMPT_MODIFIER - # without the surrounding parentheses, or to the last path component of CONDA_PREFIX if the former - # is empty. - typeset -g POWERLEVEL9K_ANACONDA_CONTENT_EXPANSION='${${${${CONDA_PROMPT_MODIFIER#\(}% }%\)}:-${CONDA_PREFIX:t}}' - - # Custom icon. - # typeset -g POWERLEVEL9K_ANACONDA_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ################[ pyenv: python environment (https://github.com/pyenv/pyenv) ]################ - # Pyenv color. - typeset -g POWERLEVEL9K_PYENV_FOREGROUND=6 - # Hide python version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_PYENV_SOURCES=(shell local global) - # If set to false, hide python version if it's the same as global: - # $(pyenv version-name) == $(pyenv global). - typeset -g POWERLEVEL9K_PYENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide python version if it's equal to "system". - typeset -g POWERLEVEL9K_PYENV_SHOW_SYSTEM=true - - # Pyenv segment format. The following parameters are available within the expansion. - # - # - P9K_CONTENT Current pyenv environment (pyenv version-name). - # - P9K_PYENV_PYTHON_VERSION Current python version (python --version). - # - # The default format has the following logic: - # - # 1. Display just "$P9K_CONTENT" if it's equal to "$P9K_PYENV_PYTHON_VERSION" or - # starts with "$P9K_PYENV_PYTHON_VERSION/". - # 2. Otherwise display "$P9K_CONTENT $P9K_PYENV_PYTHON_VERSION". - typeset -g POWERLEVEL9K_PYENV_CONTENT_EXPANSION='${P9K_CONTENT}${${P9K_CONTENT:#$P9K_PYENV_PYTHON_VERSION(|/*)}:+ $P9K_PYENV_PYTHON_VERSION}' - - # Custom icon. - # typeset -g POWERLEVEL9K_PYENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ################[ goenv: go environment (https://github.com/syndbg/goenv) ]################ - # Goenv color. - typeset -g POWERLEVEL9K_GOENV_FOREGROUND=6 - # Hide go version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_GOENV_SOURCES=(shell local global) - # If set to false, hide go version if it's the same as global: - # $(goenv version-name) == $(goenv global). - typeset -g POWERLEVEL9K_GOENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide go version if it's equal to "system". - typeset -g POWERLEVEL9K_GOENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_GOENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##########[ nodenv: node.js version from nodenv (https://github.com/nodenv/nodenv) ]########## - # Nodenv color. - typeset -g POWERLEVEL9K_NODENV_FOREGROUND=2 - # Hide node version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_NODENV_SOURCES=(shell local global) - # If set to false, hide node version if it's the same as global: - # $(nodenv version-name) == $(nodenv global). - typeset -g POWERLEVEL9K_NODENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide node version if it's equal to "system". - typeset -g POWERLEVEL9K_NODENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_NODENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##############[ nvm: node.js version from nvm (https://github.com/nvm-sh/nvm) ]############### - # Nvm color. - typeset -g POWERLEVEL9K_NVM_FOREGROUND=2 - # If set to false, hide node version if it's the same as default: - # $(nvm version current) == $(nvm version default). - typeset -g POWERLEVEL9K_NVM_PROMPT_ALWAYS_SHOW=false - # If set to false, hide node version if it's equal to "system". - typeset -g POWERLEVEL9K_NVM_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_NVM_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ############[ nodeenv: node.js environment (https://github.com/ekalinin/nodeenv) ]############ - # Nodeenv color. - typeset -g POWERLEVEL9K_NODEENV_FOREGROUND=2 - # Don't show Node version next to the environment name. - typeset -g POWERLEVEL9K_NODEENV_SHOW_NODE_VERSION=false - # Separate environment name from Node version only with a space. - typeset -g POWERLEVEL9K_NODEENV_{LEFT,RIGHT}_DELIMITER= - # Custom icon. - # typeset -g POWERLEVEL9K_NODEENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##############################[ node_version: node.js version ]############################### - # Node version color. - typeset -g POWERLEVEL9K_NODE_VERSION_FOREGROUND=2 - # Show node version only when in a directory tree containing package.json. - typeset -g POWERLEVEL9K_NODE_VERSION_PROJECT_ONLY=true - # Custom icon. - # typeset -g POWERLEVEL9K_NODE_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #######################[ go_version: go version (https://golang.org) ]######################## - # Go version color. - typeset -g POWERLEVEL9K_GO_VERSION_FOREGROUND=6 - # Show go version only when in a go project subdirectory. - typeset -g POWERLEVEL9K_GO_VERSION_PROJECT_ONLY=true - # Custom icon. - # typeset -g POWERLEVEL9K_GO_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #################[ rust_version: rustc version (https://www.rust-lang.org) ]################## - # Rust version color. - typeset -g POWERLEVEL9K_RUST_VERSION_FOREGROUND=4 - # Show rust version only when in a rust project subdirectory. - typeset -g POWERLEVEL9K_RUST_VERSION_PROJECT_ONLY=true - # Custom icon. - # typeset -g POWERLEVEL9K_RUST_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###############[ dotnet_version: .NET version (https://dotnet.microsoft.com) ]################ - # .NET version color. - typeset -g POWERLEVEL9K_DOTNET_VERSION_FOREGROUND=5 - # Show .NET version only when in a .NET project subdirectory. - typeset -g POWERLEVEL9K_DOTNET_VERSION_PROJECT_ONLY=true - # Custom icon. - # typeset -g POWERLEVEL9K_DOTNET_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #####################[ php_version: php version (https://www.php.net/) ]###################### - # PHP version color. - typeset -g POWERLEVEL9K_PHP_VERSION_FOREGROUND=5 - # Show PHP version only when in a PHP project subdirectory. - typeset -g POWERLEVEL9K_PHP_VERSION_PROJECT_ONLY=true - # Custom icon. - # typeset -g POWERLEVEL9K_PHP_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##########[ laravel_version: laravel php framework version (https://laravel.com/) ]########### - # Laravel version color. - typeset -g POWERLEVEL9K_LARAVEL_VERSION_FOREGROUND=1 - # Custom icon. - # typeset -g POWERLEVEL9K_LARAVEL_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ####################[ java_version: java version (https://www.java.com/) ]#################### - # Java version color. - typeset -g POWERLEVEL9K_JAVA_VERSION_FOREGROUND=4 - # Show java version only when in a java project subdirectory. - typeset -g POWERLEVEL9K_JAVA_VERSION_PROJECT_ONLY=true - # Show brief version. - typeset -g POWERLEVEL9K_JAVA_VERSION_FULL=false - # Custom icon. - # typeset -g POWERLEVEL9K_JAVA_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###[ package: name@version from package.json (https://docs.npmjs.com/files/package.json) ]#### - # Package color. - typeset -g POWERLEVEL9K_PACKAGE_FOREGROUND=6 - # Package format. The following parameters are available within the expansion. - # - # - P9K_PACKAGE_NAME The value of `name` field in package.json. - # - P9K_PACKAGE_VERSION The value of `version` field in package.json. - # - # typeset -g POWERLEVEL9K_PACKAGE_CONTENT_EXPANSION='${P9K_PACKAGE_NAME//\%/%%}@${P9K_PACKAGE_VERSION//\%/%%}' - # Custom icon. - # typeset -g POWERLEVEL9K_PACKAGE_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #############[ rbenv: ruby version from rbenv (https://github.com/rbenv/rbenv) ]############## - # Rbenv color. - typeset -g POWERLEVEL9K_RBENV_FOREGROUND=1 - # Hide ruby version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_RBENV_SOURCES=(shell local global) - # If set to false, hide ruby version if it's the same as global: - # $(rbenv version-name) == $(rbenv global). - typeset -g POWERLEVEL9K_RBENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide ruby version if it's equal to "system". - typeset -g POWERLEVEL9K_RBENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_RBENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #######################[ rvm: ruby version from rvm (https://rvm.io) ]######################## - # Rvm color. - typeset -g POWERLEVEL9K_RVM_FOREGROUND=1 - # Don't show @gemset at the end. - typeset -g POWERLEVEL9K_RVM_SHOW_GEMSET=false - # Don't show ruby- at the front. - typeset -g POWERLEVEL9K_RVM_SHOW_PREFIX=false - # Custom icon. - # typeset -g POWERLEVEL9K_RVM_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###########[ fvm: flutter version management (https://github.com/leoafarias/fvm) ]############ - # Fvm color. - typeset -g POWERLEVEL9K_FVM_FOREGROUND=4 - # Custom icon. - # typeset -g POWERLEVEL9K_FVM_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##########[ luaenv: lua version from luaenv (https://github.com/cehoffman/luaenv) ]########### - # Lua color. - typeset -g POWERLEVEL9K_LUAENV_FOREGROUND=4 - # Hide lua version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_LUAENV_SOURCES=(shell local global) - # If set to false, hide lua version if it's the same as global: - # $(luaenv version-name) == $(luaenv global). - typeset -g POWERLEVEL9K_LUAENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide lua version if it's equal to "system". - typeset -g POWERLEVEL9K_LUAENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_LUAENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###############[ jenv: java version from jenv (https://github.com/jenv/jenv) ]################ - # Java color. - typeset -g POWERLEVEL9K_JENV_FOREGROUND=4 - # Hide java version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_JENV_SOURCES=(shell local global) - # If set to false, hide java version if it's the same as global: - # $(jenv version-name) == $(jenv global). - typeset -g POWERLEVEL9K_JENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide java version if it's equal to "system". - typeset -g POWERLEVEL9K_JENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_JENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###########[ plenv: perl version from plenv (https://github.com/tokuhirom/plenv) ]############ - # Perl color. - typeset -g POWERLEVEL9K_PLENV_FOREGROUND=6 - # Hide perl version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_PLENV_SOURCES=(shell local global) - # If set to false, hide perl version if it's the same as global: - # $(plenv version-name) == $(plenv global). - typeset -g POWERLEVEL9K_PLENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide perl version if it's equal to "system". - typeset -g POWERLEVEL9K_PLENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_PLENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###########[ perlbrew: perl version from perlbrew (https://github.com/gugod/App-perlbrew) ]############ - # Perlbrew color. - typeset -g POWERLEVEL9K_PERLBREW_FOREGROUND=67 - # Show perlbrew version only when in a perl project subdirectory. - typeset -g POWERLEVEL9K_PERLBREW_PROJECT_ONLY=true - # Don't show "perl-" at the front. - typeset -g POWERLEVEL9K_PERLBREW_SHOW_PREFIX=false - # Custom icon. - # typeset -g POWERLEVEL9K_PERLBREW_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ############[ phpenv: php version from phpenv (https://github.com/phpenv/phpenv) ]############ - # PHP color. - typeset -g POWERLEVEL9K_PHPENV_FOREGROUND=5 - # Hide php version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_PHPENV_SOURCES=(shell local global) - # If set to false, hide php version if it's the same as global: - # $(phpenv version-name) == $(phpenv global). - typeset -g POWERLEVEL9K_PHPENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide php version if it's equal to "system". - typeset -g POWERLEVEL9K_PHPENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_PHPENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #######[ scalaenv: scala version from scalaenv (https://github.com/scalaenv/scalaenv) ]####### - # Scala color. - typeset -g POWERLEVEL9K_SCALAENV_FOREGROUND=1 - # Hide scala version if it doesn't come from one of these sources. - typeset -g POWERLEVEL9K_SCALAENV_SOURCES=(shell local global) - # If set to false, hide scala version if it's the same as global: - # $(scalaenv version-name) == $(scalaenv global). - typeset -g POWERLEVEL9K_SCALAENV_PROMPT_ALWAYS_SHOW=false - # If set to false, hide scala version if it's equal to "system". - typeset -g POWERLEVEL9K_SCALAENV_SHOW_SYSTEM=true - # Custom icon. - # typeset -g POWERLEVEL9K_SCALAENV_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ##########[ haskell_stack: haskell version from stack (https://haskellstack.org/) ]########### - # Haskell color. - typeset -g POWERLEVEL9K_HASKELL_STACK_FOREGROUND=3 - # Hide haskell version if it doesn't come from one of these sources. - # - # shell: version is set by STACK_YAML - # local: version is set by stack.yaml up the directory tree - # global: version is set by the implicit global project (~/.stack/global-project/stack.yaml) - typeset -g POWERLEVEL9K_HASKELL_STACK_SOURCES=(shell local) - # If set to false, hide haskell version if it's the same as in the implicit global project. - typeset -g POWERLEVEL9K_HASKELL_STACK_ALWAYS_SHOW=true - # Custom icon. - # typeset -g POWERLEVEL9K_HASKELL_STACK_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #############[ kubecontext: current kubernetes context (https://kubernetes.io/) ]############# - # Show kubecontext only when the command you are typing invokes one of these tools. - # Tip: Remove the next line to always show kubecontext. - typeset -g POWERLEVEL9K_KUBECONTEXT_SHOW_ON_COMMAND='kubectl|helm|kubens|kubectx|oc|istioctl|kogito|k9s|helmfile|flux|fluxctl|stern|kubeseal|skaffold|kubent|kubecolor' - - # Kubernetes context classes for the purpose of using different colors, icons and expansions with - # different contexts. - # - # POWERLEVEL9K_KUBECONTEXT_CLASSES is an array with even number of elements. The first element - # in each pair defines a pattern against which the current kubernetes context gets matched. - # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) - # that gets matched. If you unset all POWERLEVEL9K_KUBECONTEXT_*CONTENT_EXPANSION parameters, - # you'll see this value in your prompt. The second element of each pair in - # POWERLEVEL9K_KUBECONTEXT_CLASSES defines the context class. Patterns are tried in order. The - # first match wins. - # - # For example, given these settings: - # - # typeset -g POWERLEVEL9K_KUBECONTEXT_CLASSES=( - # '*prod*' PROD - # '*test*' TEST - # '*' DEFAULT) - # - # If your current kubernetes context is "deathray-testing/default", its class is TEST - # because "deathray-testing/default" doesn't match the pattern '*prod*' but does match '*test*'. - # - # You can define different colors, icons and content expansions for different classes: - # - # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_FOREGROUND=3 - # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' - typeset -g POWERLEVEL9K_KUBECONTEXT_CLASSES=( - # '*prod*' PROD # These values are examples that are unlikely - # '*test*' TEST # to match your needs. Customize them as needed. - '*' DEFAULT) - typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_FOREGROUND=5 - typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='○' - - # Use POWERLEVEL9K_KUBECONTEXT_CONTENT_EXPANSION to specify the content displayed by kubecontext - # segment. Parameter expansions are very flexible and fast, too. See reference: - # http://zsh.sourceforge.net/Doc/Release/Expansion.html#Parameter-Expansion. - # - # Within the expansion the following parameters are always available: - # - # - P9K_CONTENT The content that would've been displayed if there was no content - # expansion defined. - # - P9K_KUBECONTEXT_NAME The current context's name. Corresponds to column NAME in the - # output of `kubectl config get-contexts`. - # - P9K_KUBECONTEXT_CLUSTER The current context's cluster. Corresponds to column CLUSTER in the - # output of `kubectl config get-contexts`. - # - P9K_KUBECONTEXT_NAMESPACE The current context's namespace. Corresponds to column NAMESPACE - # in the output of `kubectl config get-contexts`. If there is no - # namespace, the parameter is set to "default". - # - P9K_KUBECONTEXT_USER The current context's user. Corresponds to column AUTHINFO in the - # output of `kubectl config get-contexts`. - # - # If the context points to Google Kubernetes Engine (GKE) or Elastic Kubernetes Service (EKS), - # the following extra parameters are available: - # - # - P9K_KUBECONTEXT_CLOUD_NAME Either "gke" or "eks". - # - P9K_KUBECONTEXT_CLOUD_ACCOUNT Account/project ID. - # - P9K_KUBECONTEXT_CLOUD_ZONE Availability zone. - # - P9K_KUBECONTEXT_CLOUD_CLUSTER Cluster. - # - # P9K_KUBECONTEXT_CLOUD_* parameters are derived from P9K_KUBECONTEXT_CLUSTER. For example, - # if P9K_KUBECONTEXT_CLUSTER is "gke_my-account_us-east1-a_my-cluster-01": - # - # - P9K_KUBECONTEXT_CLOUD_NAME=gke - # - P9K_KUBECONTEXT_CLOUD_ACCOUNT=my-account - # - P9K_KUBECONTEXT_CLOUD_ZONE=us-east1-a - # - P9K_KUBECONTEXT_CLOUD_CLUSTER=my-cluster-01 - # - # If P9K_KUBECONTEXT_CLUSTER is "arn:aws:eks:us-east-1:123456789012:cluster/my-cluster-01": - # - # - P9K_KUBECONTEXT_CLOUD_NAME=eks - # - P9K_KUBECONTEXT_CLOUD_ACCOUNT=123456789012 - # - P9K_KUBECONTEXT_CLOUD_ZONE=us-east-1 - # - P9K_KUBECONTEXT_CLOUD_CLUSTER=my-cluster-01 - typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION= - # Show P9K_KUBECONTEXT_CLOUD_CLUSTER if it's not empty and fall back to P9K_KUBECONTEXT_NAME. - POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION+='${P9K_KUBECONTEXT_CLOUD_CLUSTER:-${P9K_KUBECONTEXT_NAME}}' - # Append the current context's namespace if it's not "default". - POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION+='${${:-/$P9K_KUBECONTEXT_NAMESPACE}:#/default}' - - # Custom prefix. - typeset -g POWERLEVEL9K_KUBECONTEXT_PREFIX='%fat ' - - ################[ terraform: terraform workspace (https://www.terraform.io) ]################# - # Don't show terraform workspace if it's literally "default". - typeset -g POWERLEVEL9K_TERRAFORM_SHOW_DEFAULT=false - # POWERLEVEL9K_TERRAFORM_CLASSES is an array with even number of elements. The first element - # in each pair defines a pattern against which the current terraform workspace gets matched. - # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) - # that gets matched. If you unset all POWERLEVEL9K_TERRAFORM_*CONTENT_EXPANSION parameters, - # you'll see this value in your prompt. The second element of each pair in - # POWERLEVEL9K_TERRAFORM_CLASSES defines the workspace class. Patterns are tried in order. The - # first match wins. - # - # For example, given these settings: - # - # typeset -g POWERLEVEL9K_TERRAFORM_CLASSES=( - # '*prod*' PROD - # '*test*' TEST - # '*' OTHER) - # - # If your current terraform workspace is "project_test", its class is TEST because "project_test" - # doesn't match the pattern '*prod*' but does match '*test*'. - # - # You can define different colors, icons and content expansions for different classes: - # - # typeset -g POWERLEVEL9K_TERRAFORM_TEST_FOREGROUND=2 - # typeset -g POWERLEVEL9K_TERRAFORM_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_TERRAFORM_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' - typeset -g POWERLEVEL9K_TERRAFORM_CLASSES=( - # '*prod*' PROD # These values are examples that are unlikely - # '*test*' TEST # to match your needs. Customize them as needed. - '*' OTHER) - typeset -g POWERLEVEL9K_TERRAFORM_OTHER_FOREGROUND=4 - # typeset -g POWERLEVEL9K_TERRAFORM_OTHER_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #############[ terraform_version: terraform version (https://www.terraform.io) ]############## - # Terraform version color. - typeset -g POWERLEVEL9K_TERRAFORM_VERSION_FOREGROUND=4 - # Custom icon. - # typeset -g POWERLEVEL9K_TERRAFORM_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #[ aws: aws profile (https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-profiles.html) ]# - # Show aws only when the command you are typing invokes one of these tools. - # Tip: Remove the next line to always show aws. - typeset -g POWERLEVEL9K_AWS_SHOW_ON_COMMAND='aws|awless|terraform|pulumi|terragrunt' - - # POWERLEVEL9K_AWS_CLASSES is an array with even number of elements. The first element - # in each pair defines a pattern against which the current AWS profile gets matched. - # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) - # that gets matched. If you unset all POWERLEVEL9K_AWS_*CONTENT_EXPANSION parameters, - # you'll see this value in your prompt. The second element of each pair in - # POWERLEVEL9K_AWS_CLASSES defines the profile class. Patterns are tried in order. The - # first match wins. - # - # For example, given these settings: - # - # typeset -g POWERLEVEL9K_AWS_CLASSES=( - # '*prod*' PROD - # '*test*' TEST - # '*' DEFAULT) - # - # If your current AWS profile is "company_test", its class is TEST - # because "company_test" doesn't match the pattern '*prod*' but does match '*test*'. - # - # You can define different colors, icons and content expansions for different classes: - # - # typeset -g POWERLEVEL9K_AWS_TEST_FOREGROUND=2 - # typeset -g POWERLEVEL9K_AWS_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_AWS_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' - typeset -g POWERLEVEL9K_AWS_CLASSES=( - # '*prod*' PROD # These values are examples that are unlikely - # '*test*' TEST # to match your needs. Customize them as needed. - '*' DEFAULT) - typeset -g POWERLEVEL9K_AWS_DEFAULT_FOREGROUND=3 - # typeset -g POWERLEVEL9K_AWS_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐' - - # AWS segment format. The following parameters are available within the expansion. - # - # - P9K_AWS_PROFILE The name of the current AWS profile. - # - P9K_AWS_REGION The region associated with the current AWS profile. - typeset -g POWERLEVEL9K_AWS_CONTENT_EXPANSION='${P9K_AWS_PROFILE//\%/%%}${P9K_AWS_REGION:+ ${P9K_AWS_REGION//\%/%%}}' - - #[ aws_eb_env: aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) ]# - # AWS Elastic Beanstalk environment color. - typeset -g POWERLEVEL9K_AWS_EB_ENV_FOREGROUND=2 - # Custom icon. - typeset -g POWERLEVEL9K_AWS_EB_ENV_VISUAL_IDENTIFIER_EXPANSION='eb' - - ##########[ azure: azure account name (https://docs.microsoft.com/en-us/cli/azure) ]########## - # Show azure only when the command you are typing invokes one of these tools. - # Tip: Remove the next line to always show azure. - typeset -g POWERLEVEL9K_AZURE_SHOW_ON_COMMAND='az|terraform|pulumi|terragrunt' - # Azure account name color. - typeset -g POWERLEVEL9K_AZURE_FOREGROUND=4 - # Custom icon. - typeset -g POWERLEVEL9K_AZURE_VISUAL_IDENTIFIER_EXPANSION='az' - - ##########[ gcloud: google cloud account and project (https://cloud.google.com/) ]########### - # Show gcloud only when the command you are typing invokes one of these tools. - # Tip: Remove the next line to always show gcloud. - typeset -g POWERLEVEL9K_GCLOUD_SHOW_ON_COMMAND='gcloud|gcs|gsutil' - # Google cloud color. - typeset -g POWERLEVEL9K_GCLOUD_FOREGROUND=4 - - # Google cloud format. Change the value of POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION and/or - # POWERLEVEL9K_GCLOUD_COMPLETE_CONTENT_EXPANSION if the default is too verbose or not informative - # enough. You can use the following parameters in the expansions. Each of them corresponds to the - # output of `gcloud` tool. - # - # Parameter | Source - # -------------------------|-------------------------------------------------------------------- - # P9K_GCLOUD_CONFIGURATION | gcloud config configurations list --format='value(name)' - # P9K_GCLOUD_ACCOUNT | gcloud config get-value account - # P9K_GCLOUD_PROJECT_ID | gcloud config get-value project - # P9K_GCLOUD_PROJECT_NAME | gcloud projects describe $P9K_GCLOUD_PROJECT_ID --format='value(name)' - # - # Note: ${VARIABLE//\%/%%} expands to ${VARIABLE} with all occurrences of '%' replaced with '%%'. - # - # Obtaining project name requires sending a request to Google servers. This can take a long time - # and even fail. When project name is unknown, P9K_GCLOUD_PROJECT_NAME is not set and gcloud - # prompt segment is in state PARTIAL. When project name gets known, P9K_GCLOUD_PROJECT_NAME gets - # set and gcloud prompt segment transitions to state COMPLETE. - # - # You can customize the format, icon and colors of gcloud segment separately for states PARTIAL - # and COMPLETE. You can also hide gcloud in state PARTIAL by setting - # POWERLEVEL9K_GCLOUD_PARTIAL_VISUAL_IDENTIFIER_EXPANSION and - # POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION to empty. - typeset -g POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION='${P9K_GCLOUD_PROJECT_ID//\%/%%}' - typeset -g POWERLEVEL9K_GCLOUD_COMPLETE_CONTENT_EXPANSION='${P9K_GCLOUD_PROJECT_NAME//\%/%%}' - - # Send a request to Google (by means of `gcloud projects describe ...`) to obtain project name - # this often. Negative value disables periodic polling. In this mode project name is retrieved - # only when the current configuration, account or project id changes. - typeset -g POWERLEVEL9K_GCLOUD_REFRESH_PROJECT_NAME_SECONDS=60 - - # Custom icon. - # typeset -g POWERLEVEL9K_GCLOUD_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #[ google_app_cred: google application credentials (https://cloud.google.com/docs/authentication/production) ]# - # Show google_app_cred only when the command you are typing invokes one of these tools. - # Tip: Remove the next line to always show google_app_cred. - typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_SHOW_ON_COMMAND='terraform|pulumi|terragrunt' - - # Google application credentials classes for the purpose of using different colors, icons and - # expansions with different credentials. - # - # POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES is an array with even number of elements. The first - # element in each pair defines a pattern against which the current kubernetes context gets - # matched. More specifically, it's P9K_CONTENT prior to the application of context expansion - # (see below) that gets matched. If you unset all POWERLEVEL9K_GOOGLE_APP_CRED_*CONTENT_EXPANSION - # parameters, you'll see this value in your prompt. The second element of each pair in - # POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES defines the context class. Patterns are tried in order. - # The first match wins. - # - # For example, given these settings: - # - # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES=( - # '*:*prod*:*' PROD - # '*:*test*:*' TEST - # '*' DEFAULT) - # - # If your current Google application credentials is "service_account deathray-testing x@y.com", - # its class is TEST because it doesn't match the pattern '* *prod* *' but does match '* *test* *'. - # - # You can define different colors, icons and content expansions for different classes: - # - # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_FOREGROUND=3 - # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' - # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_CONTENT_EXPANSION='$P9K_GOOGLE_APP_CRED_PROJECT_ID' - typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES=( - # '*:*prod*:*' PROD # These values are examples that are unlikely - # '*:*test*:*' TEST # to match your needs. Customize them as needed. - '*' DEFAULT) - typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_FOREGROUND=5 - # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐' - - # Use POWERLEVEL9K_GOOGLE_APP_CRED_CONTENT_EXPANSION to specify the content displayed by - # google_app_cred segment. Parameter expansions are very flexible and fast, too. See reference: - # http://zsh.sourceforge.net/Doc/Release/Expansion.html#Parameter-Expansion. - # - # You can use the following parameters in the expansion. Each of them corresponds to one of the - # fields in the JSON file pointed to by GOOGLE_APPLICATION_CREDENTIALS. - # - # Parameter | JSON key file field - # ---------------------------------+--------------- - # P9K_GOOGLE_APP_CRED_TYPE | type - # P9K_GOOGLE_APP_CRED_PROJECT_ID | project_id - # P9K_GOOGLE_APP_CRED_CLIENT_EMAIL | client_email - # - # Note: ${VARIABLE//\%/%%} expands to ${VARIABLE} with all occurrences of '%' replaced by '%%'. - typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_CONTENT_EXPANSION='${P9K_GOOGLE_APP_CRED_PROJECT_ID//\%/%%}' - - ##############[ toolbox: toolbox name (https://github.com/containers/toolbox) ]############### - # Toolbox color. - typeset -g POWERLEVEL9K_TOOLBOX_FOREGROUND=3 - # Don't display the name of the toolbox if it matches fedora-toolbox-*. - typeset -g POWERLEVEL9K_TOOLBOX_CONTENT_EXPANSION='${P9K_TOOLBOX_NAME:#fedora-toolbox-*}' - # Custom icon. - # typeset -g POWERLEVEL9K_TOOLBOX_VISUAL_IDENTIFIER_EXPANSION='⭐' - # Custom prefix. - typeset -g POWERLEVEL9K_TOOLBOX_PREFIX='%fin ' - - ###############################[ public_ip: public IP address ]############################### - # Public IP color. - typeset -g POWERLEVEL9K_PUBLIC_IP_FOREGROUND=6 - # Custom icon. - # typeset -g POWERLEVEL9K_PUBLIC_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ########################[ vpn_ip: virtual private network indicator ]######################### - # VPN IP color. - typeset -g POWERLEVEL9K_VPN_IP_FOREGROUND=3 - # When on VPN, show just an icon without the IP address. - # Tip: To display the private IP address when on VPN, remove the next line. - typeset -g POWERLEVEL9K_VPN_IP_CONTENT_EXPANSION= - # Regular expression for the VPN network interface. Run `ifconfig` or `ip -4 a show` while on VPN - # to see the name of the interface. - typeset -g POWERLEVEL9K_VPN_IP_INTERFACE='(gpd|wg|(.*tun)|tailscale)[0-9]*|(zt.*)' - # If set to true, show one segment per matching network interface. If set to false, show only - # one segment corresponding to the first matching network interface. - # Tip: If you set it to true, you'll probably want to unset POWERLEVEL9K_VPN_IP_CONTENT_EXPANSION. - typeset -g POWERLEVEL9K_VPN_IP_SHOW_ALL=false - # Custom icon. - # typeset -g POWERLEVEL9K_VPN_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ###########[ ip: ip address and bandwidth usage for a specified network interface ]########### - # IP color. - typeset -g POWERLEVEL9K_IP_FOREGROUND=4 - # The following parameters are accessible within the expansion: - # - # Parameter | Meaning - # ----------------------+------------------------------------------- - # P9K_IP_IP | IP address - # P9K_IP_INTERFACE | network interface - # P9K_IP_RX_BYTES | total number of bytes received - # P9K_IP_TX_BYTES | total number of bytes sent - # P9K_IP_RX_BYTES_DELTA | number of bytes received since last prompt - # P9K_IP_TX_BYTES_DELTA | number of bytes sent since last prompt - # P9K_IP_RX_RATE | receive rate (since last prompt) - # P9K_IP_TX_RATE | send rate (since last prompt) - typeset -g POWERLEVEL9K_IP_CONTENT_EXPANSION='$P9K_IP_IP${P9K_IP_RX_RATE:+ %2F⇣$P9K_IP_RX_RATE}${P9K_IP_TX_RATE:+ %3F⇡$P9K_IP_TX_RATE}' - # Show information for the first network interface whose name matches this regular expression. - # Run `ifconfig` or `ip -4 a show` to see the names of all network interfaces. - typeset -g POWERLEVEL9K_IP_INTERFACE='[ew].*' - # Custom icon. - # typeset -g POWERLEVEL9K_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' - - #########################[ proxy: system-wide http/https/ftp proxy ]########################## - # Proxy color. - typeset -g POWERLEVEL9K_PROXY_FOREGROUND=2 - # Custom icon. - # typeset -g POWERLEVEL9K_PROXY_VISUAL_IDENTIFIER_EXPANSION='⭐' - - ################################[ battery: internal battery ]################################# - # Show battery in red when it's below this level and not connected to power supply. - typeset -g POWERLEVEL9K_BATTERY_LOW_THRESHOLD=20 - typeset -g POWERLEVEL9K_BATTERY_LOW_FOREGROUND=1 - # Show battery in green when it's charging or fully charged. - typeset -g POWERLEVEL9K_BATTERY_{CHARGING,CHARGED}_FOREGROUND=2 - # Show battery in yellow when it's discharging. - typeset -g POWERLEVEL9K_BATTERY_DISCONNECTED_FOREGROUND=3 - # Battery pictograms going from low to high level of charge. - typeset -g POWERLEVEL9K_BATTERY_STAGES=('%K{0}▁' '%K{0}▂' '%K{0}▃' '%K{0}▄' '%K{0}▅' '%K{0}▆' '%K{0}▇' '%K{0}█') - # Don't show the remaining time to charge/discharge. - typeset -g POWERLEVEL9K_BATTERY_VERBOSE=false - - #####################################[ wifi: wifi speed ]##################################### - # WiFi color. - typeset -g POWERLEVEL9K_WIFI_FOREGROUND=4 - # Custom icon. - # typeset -g POWERLEVEL9K_WIFI_VISUAL_IDENTIFIER_EXPANSION='⭐' - - # Use different colors and icons depending on signal strength ($P9K_WIFI_BARS). - # - # # Wifi colors and icons for different signal strength levels (low to high). - # typeset -g my_wifi_fg=(4 4 4 4 4) # <-- change these values - # typeset -g my_wifi_icon=('WiFi' 'WiFi' 'WiFi' 'WiFi' 'WiFi') # <-- change these values - # - # typeset -g POWERLEVEL9K_WIFI_CONTENT_EXPANSION='%F{${my_wifi_fg[P9K_WIFI_BARS+1]}}$P9K_WIFI_LAST_TX_RATE Mbps' - # typeset -g POWERLEVEL9K_WIFI_VISUAL_IDENTIFIER_EXPANSION='%F{${my_wifi_fg[P9K_WIFI_BARS+1]}}${my_wifi_icon[P9K_WIFI_BARS+1]}' - # - # The following parameters are accessible within the expansions: - # - # Parameter | Meaning - # ----------------------+--------------- - # P9K_WIFI_SSID | service set identifier, a.k.a. network name - # P9K_WIFI_LINK_AUTH | authentication protocol such as "wpa2-psk" or "none"; empty if unknown - # P9K_WIFI_LAST_TX_RATE | wireless transmit rate in megabits per second - # P9K_WIFI_RSSI | signal strength in dBm, from -120 to 0 - # P9K_WIFI_NOISE | noise in dBm, from -120 to 0 - # P9K_WIFI_BARS | signal strength in bars, from 0 to 4 (derived from P9K_WIFI_RSSI and P9K_WIFI_NOISE) - - ####################################[ time: current time ]#################################### - # Current time color. - typeset -g POWERLEVEL9K_TIME_FOREGROUND=6 - # Format for the current time: 09:51:02. See `man 3 strftime`. - typeset -g POWERLEVEL9K_TIME_FORMAT='%D{%I:%M:%S %p}' - # If set to true, time will update when you hit enter. This way prompts for the past - # commands will contain the start times of their commands as opposed to the default - # behavior where they contain the end times of their preceding commands. - typeset -g POWERLEVEL9K_TIME_UPDATE_ON_COMMAND=false - # Custom icon. - typeset -g POWERLEVEL9K_TIME_VISUAL_IDENTIFIER_EXPANSION= - # Custom prefix. - typeset -g POWERLEVEL9K_TIME_PREFIX='%fat ' - - # Example of a user-defined prompt segment. Function prompt_example will be called on every - # prompt if `example` prompt segment is added to POWERLEVEL9K_LEFT_PROMPT_ELEMENTS or - # POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS. It displays an icon and green text greeting the user. - # - # Type `p10k help segment` for documentation and a more sophisticated example. - function prompt_example() { - p10k segment -f 2 -i '⭐' -t 'hello, %n' - } - - # User-defined prompt segments may optionally provide an instant_prompt_* function. Its job - # is to generate the prompt segment for display in instant prompt. See - # https://github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt. - # - # Powerlevel10k will call instant_prompt_* at the same time as the regular prompt_* function - # and will record all `p10k segment` calls it makes. When displaying instant prompt, Powerlevel10k - # will replay these calls without actually calling instant_prompt_*. It is imperative that - # instant_prompt_* always makes the same `p10k segment` calls regardless of environment. If this - # rule is not observed, the content of instant prompt will be incorrect. - # - # Usually, you should either not define instant_prompt_* or simply call prompt_* from it. If - # instant_prompt_* is not defined for a segment, the segment won't be shown in instant prompt. - function instant_prompt_example() { - # Since prompt_example always makes the same `p10k segment` calls, we can call it from - # instant_prompt_example. This will give us the same `example` prompt segment in the instant - # and regular prompts. - prompt_example - } - - # User-defined prompt segments can be customized the same way as built-in segments. - # typeset -g POWERLEVEL9K_EXAMPLE_FOREGROUND=208 - # typeset -g POWERLEVEL9K_EXAMPLE_VISUAL_IDENTIFIER_EXPANSION='⭐' - - # Transient prompt works similarly to the builtin transient_rprompt option. It trims down prompt - # when accepting a command line. Supported values: - # - # - off: Don't change prompt when accepting a command line. - # - always: Trim down prompt when accepting a command line. - # - same-dir: Trim down prompt when accepting a command line unless this is the first command - # typed after changing current working directory. - typeset -g POWERLEVEL9K_TRANSIENT_PROMPT=always - - # Instant prompt mode. - # - # - off: Disable instant prompt. Choose this if you've tried instant prompt and found - # it incompatible with your zsh configuration files. - # - quiet: Enable instant prompt and don't print warnings when detecting console output - # during zsh initialization. Choose this if you've read and understood - # https://github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt. - # - verbose: Enable instant prompt and print a warning when detecting console output during - # zsh initialization. Choose this if you've never tried instant prompt, haven't - # seen the warning, or if you are unsure what this all means. - typeset -g POWERLEVEL9K_INSTANT_PROMPT=verbose - - # Hot reload allows you to change POWERLEVEL9K options after Powerlevel10k has been initialized. - # For example, you can type POWERLEVEL9K_BACKGROUND=red and see your prompt turn red. Hot reload - # can slow down prompt by 1-2 milliseconds, so it's better to keep it turned off unless you - # really need it. - typeset -g POWERLEVEL9K_DISABLE_HOT_RELOAD=true - - # If p10k is already loaded, reload configuration. - # This works even with POWERLEVEL9K_DISABLE_HOT_RELOAD=true. - (( ! $+functions[p10k] )) || p10k reload + emulate -L zsh -o extended_glob + + # Unset all configuration options. This allows you to apply configuration changes without + # restarting zsh. Edit ~/.p10k.zsh and type `source ~/.p10k.zsh`. + unset -m '(POWERLEVEL9K_*|DEFAULT_USER)~POWERLEVEL9K_GITSTATUS_DIR' + + # Zsh >= 5.1 is required. + [[ $ZSH_VERSION == (5.<1->*|<6->.*) ]] || return + + # The list of segments shown on the left. Fill it with the most important segments. + typeset -g POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=( + # =========================[ Line #1 ]========================= + # os_icon # os identifier + dir # current directory + vcs # git status + # =========================[ Line #2 ]========================= + newline # \n + prompt_char # prompt symbol + ) + + # The list of segments shown on the right. Fill it with less important segments. + # Right prompt on the last prompt line (where you are typing your commands) gets + # automatically hidden when the input line reaches it. Right prompt above the + # last prompt line gets hidden if it would overlap with left prompt. + typeset -g POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS=( + # =========================[ Line #1 ]========================= + status # exit code of the last command + command_execution_time # duration of the last command + background_jobs # presence of background jobs + direnv # direnv status (https://direnv.net/) + asdf # asdf version manager (https://github.com/asdf-vm/asdf) + virtualenv # python virtual environment (https://docs.python.org/3/library/venv.html) + anaconda # conda environment (https://conda.io/) + pyenv # python environment (https://github.com/pyenv/pyenv) + goenv # go environment (https://github.com/syndbg/goenv) + nodenv # node.js version from nodenv (https://github.com/nodenv/nodenv) + nvm # node.js version from nvm (https://github.com/nvm-sh/nvm) + nodeenv # node.js environment (https://github.com/ekalinin/nodeenv) + # node_version # node.js version + # go_version # go version (https://golang.org) + # rust_version # rustc version (https://www.rust-lang.org) + # dotnet_version # .NET version (https://dotnet.microsoft.com) + # php_version # php version (https://www.php.net/) + # laravel_version # laravel php framework version (https://laravel.com/) + # java_version # java version (https://www.java.com/) + # package # name@version from package.json (https://docs.npmjs.com/files/package.json) + rbenv # ruby version from rbenv (https://github.com/rbenv/rbenv) + rvm # ruby version from rvm (https://rvm.io) + fvm # flutter version management (https://github.com/leoafarias/fvm) + luaenv # lua version from luaenv (https://github.com/cehoffman/luaenv) + jenv # java version from jenv (https://github.com/jenv/jenv) + plenv # perl version from plenv (https://github.com/tokuhirom/plenv) + perlbrew # perl version from perlbrew (https://github.com/gugod/App-perlbrew) + phpenv # php version from phpenv (https://github.com/phpenv/phpenv) + scalaenv # scala version from scalaenv (https://github.com/scalaenv/scalaenv) + haskell_stack # haskell version from stack (https://haskellstack.org/) + kubecontext # current kubernetes context (https://kubernetes.io/) + terraform # terraform workspace (https://www.terraform.io) + # terraform_version # terraform version (https://www.terraform.io) + aws # aws profile (https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-profiles.html) + aws_eb_env # aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) + azure # azure account name (https://docs.microsoft.com/en-us/cli/azure) + gcloud # google cloud cli account and project (https://cloud.google.com/) + google_app_cred # google application credentials (https://cloud.google.com/docs/authentication/production) + toolbox # toolbox name (https://github.com/containers/toolbox) + context # user@hostname + nordvpn # nordvpn connection status, linux only (https://nordvpn.com/) + ranger # ranger shell (https://github.com/ranger/ranger) + nnn # nnn shell (https://github.com/jarun/nnn) + lf # lf shell (https://github.com/gokcehan/lf) + xplr # xplr shell (https://github.com/sayanarijit/xplr) + vim_shell # vim shell indicator (:sh) + midnight_commander # midnight commander shell (https://midnight-commander.org/) + nix_shell # nix shell (https://nixos.org/nixos/nix-pills/developing-with-nix-shell.html) + # vpn_ip # virtual private network indicator + # load # CPU load + # disk_usage # disk usage + # ram # free RAM + # swap # used swap + todo # todo items (https://github.com/todotxt/todo.txt-cli) + timewarrior # timewarrior tracking status (https://timewarrior.net/) + taskwarrior # taskwarrior task count (https://taskwarrior.org/) + # cpu_arch # CPU architecture + time # current time + # =========================[ Line #2 ]========================= + newline # \n + # ip # ip address and bandwidth usage for a specified network interface + # public_ip # public IP address + # proxy # system-wide http/https/ftp proxy + # battery # internal battery + # wifi # wifi speed + # example # example user-defined segment (see prompt_example function below) + ) + + # Defines character set used by powerlevel10k. It's best to let `p10k configure` set it for you. + typeset -g POWERLEVEL9K_MODE=compatible + # When set to `moderate`, some icons will have an extra space after them. This is meant to avoid + # icon overlap when using non-monospace fonts. When set to `none`, spaces are not added. + typeset -g POWERLEVEL9K_ICON_PADDING=none + + # Basic style options that define the overall look of your prompt. You probably don't want to + # change them. + typeset -g POWERLEVEL9K_BACKGROUND= # transparent background + typeset -g POWERLEVEL9K_{LEFT,RIGHT}_{LEFT,RIGHT}_WHITESPACE= # no surrounding whitespace + typeset -g POWERLEVEL9K_{LEFT,RIGHT}_SUBSEGMENT_SEPARATOR=' ' # separate segments with a space + typeset -g POWERLEVEL9K_{LEFT,RIGHT}_SEGMENT_SEPARATOR= # no end-of-line symbol + + # When set to true, icons appear before content on both sides of the prompt. When set + # to false, icons go after content. If empty or not set, icons go before content in the left + # prompt and after content in the right prompt. + # + # You can also override it for a specific segment: + # + # POWERLEVEL9K_STATUS_ICON_BEFORE_CONTENT=false + # + # Or for a specific segment in specific state: + # + # POWERLEVEL9K_DIR_NOT_WRITABLE_ICON_BEFORE_CONTENT=false + typeset -g POWERLEVEL9K_ICON_BEFORE_CONTENT=true + + # Add an empty line before each prompt. + typeset -g POWERLEVEL9K_PROMPT_ADD_NEWLINE=true + + # Connect left prompt lines with these symbols. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_PREFIX='%7F╭─' + typeset -g POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_PREFIX='%7F├─' + typeset -g POWERLEVEL9K_MULTILINE_LAST_PROMPT_PREFIX='%7F╰─' + # Connect right prompt lines with these symbols. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_SUFFIX='%7F─╮' + typeset -g POWERLEVEL9K_MULTILINE_NEWLINE_PROMPT_SUFFIX='%7F─┤' + typeset -g POWERLEVEL9K_MULTILINE_LAST_PROMPT_SUFFIX='%7F─╯' + + # The left end of left prompt. + typeset -g POWERLEVEL9K_LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL=' ' + # The right end of right prompt. + typeset -g POWERLEVEL9K_RIGHT_PROMPT_LAST_SEGMENT_END_SYMBOL=' ' + + # Ruler, a.k.a. the horizontal line before each prompt. If you set it to true, you'll + # probably want to set POWERLEVEL9K_PROMPT_ADD_NEWLINE=false above and + # POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR=' ' below. + typeset -g POWERLEVEL9K_SHOW_RULER=false + typeset -g POWERLEVEL9K_RULER_CHAR='─' # reasonable alternative: '·' + typeset -g POWERLEVEL9K_RULER_FOREGROUND=7 + + # Filler between left and right prompt on the first prompt line. You can set it to '·' or '─' + # to make it easier to see the alignment between left and right prompt and to separate prompt + # from command output. It serves the same purpose as ruler (see above) without increasing + # the number of prompt lines. You'll probably want to set POWERLEVEL9K_SHOW_RULER=false + # if using this. You might also like POWERLEVEL9K_PROMPT_ADD_NEWLINE=false for more compact + # prompt. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR='─' + if [[ $POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_CHAR != ' ' ]]; then + # The color of the filler. + typeset -g POWERLEVEL9K_MULTILINE_FIRST_PROMPT_GAP_FOREGROUND=7 + # Add a space between the end of left prompt and the filler. + typeset -g POWERLEVEL9K_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL=' ' + # Add a space between the filler and the start of right prompt. + typeset -g POWERLEVEL9K_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL=' ' + # Start filler from the edge of the screen if there are no left segments on the first line. + typeset -g POWERLEVEL9K_EMPTY_LINE_LEFT_PROMPT_FIRST_SEGMENT_END_SYMBOL='%{%}' + # End filler on the edge of the screen if there are no right segments on the first line. + typeset -g POWERLEVEL9K_EMPTY_LINE_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL='%{%}' + fi + + #################################[ os_icon: os identifier ]################################## + # OS identifier color. + typeset -g POWERLEVEL9K_OS_ICON_FOREGROUND= + # Custom icon. + # typeset -g POWERLEVEL9K_OS_ICON_CONTENT_EXPANSION='⭐' + + ################################[ prompt_char: prompt symbol ]################################ + # Green prompt symbol if the last command succeeded. + typeset -g POWERLEVEL9K_PROMPT_CHAR_OK_{VIINS,VICMD,VIVIS,VIOWR}_FOREGROUND=2 + # Red prompt symbol if the last command failed. + typeset -g POWERLEVEL9K_PROMPT_CHAR_ERROR_{VIINS,VICMD,VIVIS,VIOWR}_FOREGROUND=1 + # Default prompt symbol. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIINS_CONTENT_EXPANSION='❯' + # Prompt symbol in command vi mode. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VICMD_CONTENT_EXPANSION='❮' + # Prompt symbol in visual vi mode. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIVIS_CONTENT_EXPANSION='V' + # Prompt symbol in overwrite vi mode. + typeset -g POWERLEVEL9K_PROMPT_CHAR_{OK,ERROR}_VIOWR_CONTENT_EXPANSION='▶' + typeset -g POWERLEVEL9K_PROMPT_CHAR_OVERWRITE_STATE=true + # No line terminator if prompt_char is the last segment. + typeset -g POWERLEVEL9K_PROMPT_CHAR_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL='' + # No line introducer if prompt_char is the first segment. + typeset -g POWERLEVEL9K_PROMPT_CHAR_LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL= + + ##################################[ dir: current directory ]################################## + # Default current directory color. + typeset -g POWERLEVEL9K_DIR_FOREGROUND=4 + # If directory is too long, shorten some of its segments to the shortest possible unique + # prefix. The shortened directory can be tab-completed to the original. + typeset -g POWERLEVEL9K_SHORTEN_STRATEGY=truncate_to_unique + # Replace removed segment suffixes with this symbol. + typeset -g POWERLEVEL9K_SHORTEN_DELIMITER= + # Color of the shortened directory segments. + typeset -g POWERLEVEL9K_DIR_SHORTENED_FOREGROUND=4 + # Color of the anchor directory segments. Anchor segments are never shortened. The first + # segment is always an anchor. + typeset -g POWERLEVEL9K_DIR_ANCHOR_FOREGROUND=4 + # Set to true to display anchor directory segments in bold. + typeset -g POWERLEVEL9K_DIR_ANCHOR_BOLD=false + # Don't shorten directories that contain any of these files. They are anchors. + local anchor_files=( + .bzr + .citc + .git + .hg + .node-version + .python-version + .go-version + .ruby-version + .lua-version + .java-version + .perl-version + .php-version + .tool-version + .shorten_folder_marker + .svn + .terraform + CVS + Cargo.toml + composer.json + go.mod + package.json + stack.yaml + ) + typeset -g POWERLEVEL9K_SHORTEN_FOLDER_MARKER="(${(j:|:)anchor_files})" + # If set to "first" ("last"), remove everything before the first (last) subdirectory that contains + # files matching $POWERLEVEL9K_SHORTEN_FOLDER_MARKER. For example, when the current directory is + # /foo/bar/git_repo/nested_git_repo/baz, prompt will display git_repo/nested_git_repo/baz (first) + # or nested_git_repo/baz (last). This assumes that git_repo and nested_git_repo contain markers + # and other directories don't. + # + # Optionally, "first" and "last" can be followed by ":" where is an integer. + # This moves the truncation point to the right (positive offset) or to the left (negative offset) + # relative to the marker. Plain "first" and "last" are equivalent to "first:0" and "last:0" + # respectively. + typeset -g POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER=false + # Don't shorten this many last directory segments. They are anchors. + typeset -g POWERLEVEL9K_SHORTEN_DIR_LENGTH=1 + # Shorten directory if it's longer than this even if there is space for it. The value can + # be either absolute (e.g., '80') or a percentage of terminal width (e.g, '50%'). If empty, + # directory will be shortened only when prompt doesn't fit or when other parameters demand it + # (see POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS and POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT below). + # If set to `0`, directory will always be shortened to its minimum length. + typeset -g POWERLEVEL9K_DIR_MAX_LENGTH=80 + # When `dir` segment is on the last prompt line, try to shorten it enough to leave at least this + # many columns for typing commands. + typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS=40 + # When `dir` segment is on the last prompt line, try to shorten it enough to leave at least + # COLUMNS * POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT * 0.01 columns for typing commands. + typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT=50 + # If set to true, embed a hyperlink into the directory. Useful for quickly + # opening a directory in the file manager simply by clicking the link. + # Can also be handy when the directory is shortened, as it allows you to see + # the full directory that was used in previous commands. + typeset -g POWERLEVEL9K_DIR_HYPERLINK=false + + # Enable special styling for non-writable directories. See POWERLEVEL9K_LOCK_ICON and + # POWERLEVEL9K_DIR_CLASSES below. + typeset -g POWERLEVEL9K_DIR_SHOW_WRITABLE=v2 + + # Enable special styling for non-writable and non-existent directories. See POWERLEVEL9K_LOCK_ICON + # and POWERLEVEL9K_DIR_CLASSES below. + typeset -g POWERLEVEL9K_DIR_SHOW_WRITABLE=v3 + + # The default icon shown next to non-writable and non-existent directories when + # POWERLEVEL9K_DIR_SHOW_WRITABLE is set to v3. + typeset -g POWERLEVEL9K_LOCK_ICON='∅' + + # POWERLEVEL9K_DIR_CLASSES allows you to specify custom icons and colors for different + # directories. It must be an array with 3 * N elements. Each triplet consists of: + # + # 1. A pattern against which the current directory ($PWD) is matched. Matching is done with + # extended_glob option enabled. + # 2. Directory class for the purpose of styling. + # 3. An empty string. + # + # Triplets are tried in order. The first triplet whose pattern matches $PWD wins. + # + # If POWERLEVEL9K_DIR_SHOW_WRITABLE is set to v3, non-writable and non-existent directories + # acquire class suffix _NOT_WRITABLE and NON_EXISTENT respectively. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_DIR_CLASSES=( + # '~/work(|/*)' WORK '' + # '~(|/*)' HOME '' + # '*' DEFAULT '') + # + # Whenever the current directory is ~/work or a subdirectory of ~/work, it gets styled with one + # of the following classes depending on its writability and existence: WORK, WORK_NOT_WRITABLE or + # WORK_NON_EXISTENT. + # + # Simply assigning classes to directories doesn't have any visible effects. It merely gives you an + # option to define custom colors and icons for different directory classes. + # + # # Styling for WORK. + # typeset -g POWERLEVEL9K_DIR_WORK_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_DIR_WORK_FOREGROUND=4 + # typeset -g POWERLEVEL9K_DIR_WORK_SHORTENED_FOREGROUND=4 + # typeset -g POWERLEVEL9K_DIR_WORK_ANCHOR_FOREGROUND=4 + # + # # Styling for WORK_NOT_WRITABLE. + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_FOREGROUND=4 + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_SHORTENED_FOREGROUND=4 + # typeset -g POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_ANCHOR_FOREGROUND=4# + # + # Styling for WORK_NON_EXISTENT. + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_FOREGROUND=4 + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_SHORTENED_FOREGROUND=4 + # typeset -g POWERLEVEL9K_DIR_WORK_NON_EXISTENT_ANCHOR_FOREGROUND=4 + # + # If a styling parameter isn't explicitly defined for some class, it falls back to the classless + # parameter. For example, if POWERLEVEL9K_DIR_WORK_NOT_WRITABLE_FOREGROUND is not set, it falls + # back to POWERLEVEL9K_DIR_FOREGROUND. + # + typeset -g POWERLEVEL9K_DIR_CLASSES=() + + # Custom prefix. + # typeset -g POWERLEVEL9K_DIR_PREFIX='%fin ' + + #####################################[ vcs: git status ]###################################### + # Branch icon. Set this parameter to '\UE0A0 ' for the popular Powerline branch icon. + typeset -g POWERLEVEL9K_VCS_BRANCH_ICON= + + # Untracked files icon. It's really a question mark, your font isn't broken. + # Change the value of this parameter to show a different icon. + typeset -g POWERLEVEL9K_VCS_UNTRACKED_ICON='?' + + # Formatter for Git status. + # + # Example output: master wip ⇣42⇡42 *42 merge ~42 +42 !42 ?42. + # + # You can edit the function to customize how Git status looks. + # + # VCS_STATUS_* parameters are set by gitstatus plugin. See reference: + # https://github.com/romkatv/gitstatus/blob/master/gitstatus.plugin.zsh. + function my_git_formatter() { + emulate -L zsh + + if [[ -n $P9K_CONTENT ]]; then + # If P9K_CONTENT is not empty, use it. It's either "loading" or from vcs_info (not from + # gitstatus plugin). VCS_STATUS_* parameters are not available in this case. + typeset -g my_git_format=$P9K_CONTENT + return + fi + + if (($1)); then + # Styling for up-to-date Git status. + local meta='%f' # default foreground + local clean='%2F' # green foreground + local modified='%3F' # yellow foreground + local untracked='%4F' # blue foreground + local conflicted='%1F' # red foreground + else + # Styling for incomplete and stale Git status. + local meta='%f' # default foreground + local clean='%f' # default foreground + local modified='%f' # default foreground + local untracked='%f' # default foreground + local conflicted='%f' # default foreground + fi + + local res + + if [[ -n $VCS_STATUS_LOCAL_BRANCH ]]; then + local branch=${(V)VCS_STATUS_LOCAL_BRANCH} + # If local branch name is at most 32 characters long, show it in full. + # Otherwise show the first 12 … the last 12. + # Tip: To always show local branch name in full without truncation, delete the next line. + (($#branch > 32)) && branch[13,-13]="…" # <-- this line + res+="${clean}${(g::)POWERLEVEL9K_VCS_BRANCH_ICON}${branch//\%/%%}" + fi + + if [[ -n $VCS_STATUS_TAG && + + -z $VCS_STATUS_LOCAL_BRANCH ]] \ + ; then # Show tag only if not on a branch. + # Tip: To always show tag, delete the next line. + # <-- this line + local tag=${(V)VCS_STATUS_TAG} + # If tag name is at most 32 characters long, show it in full. + # Otherwise show the first 12 … the last 12. + # Tip: To always show tag name in full without truncation, delete the next line. + (($#tag > 32)) && tag[13,-13]="…" # <-- this line + res+="${meta}#${clean}${tag//\%/%%}" + fi + + # Display the current Git commit if there is no branch and no tag. + # Tip: To always display the current Git commit, delete the next line. + [[ -z $VCS_STATUS_LOCAL_BRANCH && -z $VCS_STATUS_TAG ]] && # <-- this line + res+="${meta}@${clean}${VCS_STATUS_COMMIT[1,8]}" + + # Show tracking branch name if it differs from local branch. + if [[ -n ${VCS_STATUS_REMOTE_BRANCH:#$VCS_STATUS_LOCAL_BRANCH} ]]; then + res+="${meta}:${clean}${(V)VCS_STATUS_REMOTE_BRANCH//\%/%%}" + fi + + # Display "wip" if the latest commit's summary contains "wip" or "WIP". + if [[ $VCS_STATUS_COMMIT_SUMMARY == (|*[^[:alnum:]])(wip|WIP)(|[^[:alnum:]]*) ]]; then + res+=" ${modified}wip" + fi + + # ⇣42 if behind the remote. + ((VCS_STATUS_COMMITS_BEHIND)) && res+=" ${clean}⇣${VCS_STATUS_COMMITS_BEHIND}" + # ⇡42 if ahead of the remote; no leading space if also behind the remote: ⇣42⇡42. + ((VCS_STATUS_COMMITS_AHEAD && !VCS_STATUS_COMMITS_BEHIND)) && res+=" " + ((VCS_STATUS_COMMITS_AHEAD)) && res+="${clean}⇡${VCS_STATUS_COMMITS_AHEAD}" + # ⇠42 if behind the push remote. + ((VCS_STATUS_PUSH_COMMITS_BEHIND)) && res+=" ${clean}⇠${VCS_STATUS_PUSH_COMMITS_BEHIND}" + ((VCS_STATUS_PUSH_COMMITS_AHEAD && !VCS_STATUS_PUSH_COMMITS_BEHIND)) && res+=" " + # ⇢42 if ahead of the push remote; no leading space if also behind: ⇠42⇢42. + ((VCS_STATUS_PUSH_COMMITS_AHEAD)) && res+="${clean}⇢${VCS_STATUS_PUSH_COMMITS_AHEAD}" + # *42 if have stashes. + ((VCS_STATUS_STASHES)) && res+=" ${clean}*${VCS_STATUS_STASHES}" + # 'merge' if the repo is in an unusual state. + [[ -n $VCS_STATUS_ACTION ]] && res+=" ${conflicted}${VCS_STATUS_ACTION}" + # ~42 if have merge conflicts. + ((VCS_STATUS_NUM_CONFLICTED)) && res+=" ${conflicted}~${VCS_STATUS_NUM_CONFLICTED}" + # +42 if have staged changes. + ((VCS_STATUS_NUM_STAGED)) && res+=" ${modified}+${VCS_STATUS_NUM_STAGED}" + # !42 if have unstaged changes. + ((VCS_STATUS_NUM_UNSTAGED)) && res+=" ${modified}!${VCS_STATUS_NUM_UNSTAGED}" + # ?42 if have untracked files. It's really a question mark, your font isn't broken. + # See POWERLEVEL9K_VCS_UNTRACKED_ICON above if you want to use a different icon. + # Remove the next line if you don't want to see untracked files at all. + ((VCS_STATUS_NUM_UNTRACKED)) && res+=" ${untracked}${(g::)POWERLEVEL9K_VCS_UNTRACKED_ICON}${VCS_STATUS_NUM_UNTRACKED}" + # "─" if the number of unstaged files is unknown. This can happen due to + # POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY (see below) being set to a non-negative number lower + # than the number of files in the Git index, or due to bash.showDirtyState being set to false + # in the repository config. The number of staged and untracked files may also be unknown + # in this case. + ((VCS_STATUS_HAS_UNSTAGED == -1)) && res+=" ${modified}─" + + typeset -g my_git_format=$res + } + functions -M my_git_formatter 2>/dev/null + + # Don't count the number of unstaged, untracked and conflicted files in Git repositories with + # more than this many files in the index. Negative value means infinity. + # + # If you are working in Git repositories with tens of millions of files and seeing performance + # sagging, try setting POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY to a number lower than the output + # of `git ls-files | wc -l`. Alternatively, add `bash.showDirtyState = false` to the repository's + # config: `git config bash.showDirtyState false`. + typeset -g POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY=-1 + + # Don't show Git status in prompt for repositories whose workdir matches this pattern. + # For example, if set to '~', the Git repository at $HOME/.git will be ignored. + # Multiple patterns can be combined with '|': '~(|/foo)|/bar/baz/*'. + typeset -g POWERLEVEL9K_VCS_DISABLED_WORKDIR_PATTERN='~' + + # Disable the default Git status formatting. + typeset -g POWERLEVEL9K_VCS_DISABLE_GITSTATUS_FORMATTING=true + # Install our own Git status formatter. + typeset -g POWERLEVEL9K_VCS_CONTENT_EXPANSION='${$((my_git_formatter(1)))+${my_git_format}}' + typeset -g POWERLEVEL9K_VCS_LOADING_CONTENT_EXPANSION='${$((my_git_formatter(0)))+${my_git_format}}' + # Enable counters for staged, unstaged, etc. + typeset -g POWERLEVEL9K_VCS_{STAGED,UNSTAGED,UNTRACKED,CONFLICTED,COMMITS_AHEAD,COMMITS_BEHIND}_MAX_NUM=-1 + + # Icon color. + typeset -g POWERLEVEL9K_VCS_VISUAL_IDENTIFIER_COLOR=2 + typeset -g POWERLEVEL9K_VCS_LOADING_VISUAL_IDENTIFIER_COLOR= + # Custom icon. + typeset -g POWERLEVEL9K_VCS_VISUAL_IDENTIFIER_EXPANSION= + # Custom prefix. + typeset -g POWERLEVEL9K_VCS_PREFIX='%fon ' + + # Show status of repositories of these types. You can add svn and/or hg if you are + # using them. If you do, your prompt may become slow even when your current directory + # isn't in an svn or hg repository. + typeset -g POWERLEVEL9K_VCS_BACKENDS=(git) + + # These settings are used for repositories other than Git or when gitstatusd fails and + # Powerlevel10k has to fall back to using vcs_info. + typeset -g POWERLEVEL9K_VCS_CLEAN_FOREGROUND=2 + typeset -g POWERLEVEL9K_VCS_UNTRACKED_FOREGROUND=2 + typeset -g POWERLEVEL9K_VCS_MODIFIED_FOREGROUND=3 + + ##########################[ status: exit code of the last command ]########################### + # Enable OK_PIPE, ERROR_PIPE and ERROR_SIGNAL status states to allow us to enable, disable and + # style them independently from the regular OK and ERROR state. + typeset -g POWERLEVEL9K_STATUS_EXTENDED_STATES=true + + # Status on success. No content, just an icon. No need to show it if prompt_char is enabled as + # it will signify success by turning green. + typeset -g POWERLEVEL9K_STATUS_OK=false + typeset -g POWERLEVEL9K_STATUS_OK_FOREGROUND=2 + typeset -g POWERLEVEL9K_STATUS_OK_VISUAL_IDENTIFIER_EXPANSION='✔' + + # Status when some part of a pipe command fails but the overall exit status is zero. It may look + # like this: 1|0. + typeset -g POWERLEVEL9K_STATUS_OK_PIPE=true + typeset -g POWERLEVEL9K_STATUS_OK_PIPE_FOREGROUND=2 + typeset -g POWERLEVEL9K_STATUS_OK_PIPE_VISUAL_IDENTIFIER_EXPANSION='✔' + + # Status when it's just an error code (e.g., '1'). No need to show it if prompt_char is enabled as + # it will signify error by turning red. + typeset -g POWERLEVEL9K_STATUS_ERROR=false + typeset -g POWERLEVEL9K_STATUS_ERROR_FOREGROUND=1 + typeset -g POWERLEVEL9K_STATUS_ERROR_VISUAL_IDENTIFIER_EXPANSION='х' + + # Status when the last command was terminated by a signal. + typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL=true + typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL_FOREGROUND=1 + # Use terse signal names: "INT" instead of "SIGINT(2)". + typeset -g POWERLEVEL9K_STATUS_VERBOSE_SIGNAME=false + typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL_VISUAL_IDENTIFIER_EXPANSION='х' + + # Status when some part of a pipe command fails and the overall exit status is also non-zero. + # It may look like this: 1|0. + typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE=true + typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE_FOREGROUND=1 + typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE_VISUAL_IDENTIFIER_EXPANSION='х' + + ###################[ command_execution_time: duration of the last command ]################### + # Show duration of the last command if takes at least this many seconds. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=3 + # Show this many fractional digits. Zero means round to seconds. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=0 + # Execution time color. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FOREGROUND=3 + # Duration format: 1d 2h 3m 4s. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FORMAT='d h m s' + # Custom icon. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_VISUAL_IDENTIFIER_EXPANSION= + # Custom prefix. + typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_PREFIX='%ftook ' + + #######################[ background_jobs: presence of background jobs ]####################### + # Don't show the number of background jobs. + typeset -g POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE=false + # Background jobs color. + typeset -g POWERLEVEL9K_BACKGROUND_JOBS_FOREGROUND=1 + # Custom icon. + typeset -g POWERLEVEL9K_BACKGROUND_JOBS_VISUAL_IDENTIFIER_EXPANSION='≡' + + #######################[ direnv: direnv status (https://direnv.net/) ]######################## + # Direnv color. + typeset -g POWERLEVEL9K_DIRENV_FOREGROUND=3 + # Custom icon. + # typeset -g POWERLEVEL9K_DIRENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###############[ asdf: asdf version manager (https://github.com/asdf-vm/asdf) ]############### + # Default asdf color. Only used to display tools for which there is no color override (see below). + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_FOREGROUND. + typeset -g POWERLEVEL9K_ASDF_FOREGROUND=6 + + # There are four parameters that can be used to hide asdf tools. Each parameter describes + # conditions under which a tool gets hidden. Parameters can hide tools but not unhide them. If at + # least one parameter decides to hide a tool, that tool gets hidden. If no parameter decides to + # hide a tool, it gets shown. + # + # Special note on the difference between POWERLEVEL9K_ASDF_SOURCES and + # POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW. Consider the effect of the following commands: + # + # asdf local python 3.8.1 + # asdf global python 3.8.1 + # + # After running both commands the current python version is 3.8.1 and its source is "local" as + # it takes precedence over "global". If POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW is set to false, + # it'll hide python version in this case because 3.8.1 is the same as the global version. + # POWERLEVEL9K_ASDF_SOURCES will hide python version only if the value of this parameter doesn't + # contain "local". + + # Hide tool versions that don't come from one of these sources. + # + # Available sources: + # + # - shell `asdf current` says "set by ASDF_${TOOL}_VERSION environment variable" + # - local `asdf current` says "set by /some/not/home/directory/file" + # - global `asdf current` says "set by /home/username/file" + # + # Note: If this parameter is set to (shell local global), it won't hide tools. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SOURCES. + typeset -g POWERLEVEL9K_ASDF_SOURCES=(shell local global) + + # If set to false, hide tool versions that are the same as global. + # + # Note: The name of this parameter doesn't reflect its meaning at all. + # Note: If this parameter is set to true, it won't hide tools. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_PROMPT_ALWAYS_SHOW. + typeset -g POWERLEVEL9K_ASDF_PROMPT_ALWAYS_SHOW=false + + # If set to false, hide tool versions that are equal to "system". + # + # Note: If this parameter is set to true, it won't hide tools. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SHOW_SYSTEM. + typeset -g POWERLEVEL9K_ASDF_SHOW_SYSTEM=true + + # If set to non-empty value, hide tools unless there is a file matching the specified file pattern + # in the current directory, or its parent directory, or its grandparent directory, and so on. + # + # Note: If this parameter is set to empty value, it won't hide tools. + # Note: SHOW_ON_UPGLOB isn't specific to asdf. It works with all prompt segments. + # Tip: Override this parameter for ${TOOL} with POWERLEVEL9K_ASDF_${TOOL}_SHOW_ON_UPGLOB. + # + # Example: Hide nodejs version when there is no package.json and no *.js files in the current + # directory, in `..`, in `../..` and so on. + # + # typeset -g POWERLEVEL9K_ASDF_NODEJS_SHOW_ON_UPGLOB='*.js|package.json' + typeset -g POWERLEVEL9K_ASDF_SHOW_ON_UPGLOB= + + # Ruby version from asdf. + typeset -g POWERLEVEL9K_ASDF_RUBY_FOREGROUND=1 + # typeset -g POWERLEVEL9K_ASDF_RUBY_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_RUBY_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Python version from asdf. + typeset -g POWERLEVEL9K_ASDF_PYTHON_FOREGROUND=6 + # typeset -g POWERLEVEL9K_ASDF_PYTHON_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_PYTHON_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Go version from asdf. + typeset -g POWERLEVEL9K_ASDF_GOLANG_FOREGROUND=6 + # typeset -g POWERLEVEL9K_ASDF_GOLANG_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_GOLANG_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Node.js version from asdf. + typeset -g POWERLEVEL9K_ASDF_NODEJS_FOREGROUND=2 + # typeset -g POWERLEVEL9K_ASDF_NODEJS_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_NODEJS_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Rust version from asdf. + typeset -g POWERLEVEL9K_ASDF_RUST_FOREGROUND=4 + # typeset -g POWERLEVEL9K_ASDF_RUST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_RUST_SHOW_ON_UPGLOB='*.foo|*.bar' + + # .NET Core version from asdf. + typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_FOREGROUND=5 + # typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_DOTNET_CORE_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Flutter version from asdf. + typeset -g POWERLEVEL9K_ASDF_FLUTTER_FOREGROUND=4 + # typeset -g POWERLEVEL9K_ASDF_FLUTTER_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_FLUTTER_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Lua version from asdf. + typeset -g POWERLEVEL9K_ASDF_LUA_FOREGROUND=4 + # typeset -g POWERLEVEL9K_ASDF_LUA_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_LUA_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Java version from asdf. + typeset -g POWERLEVEL9K_ASDF_JAVA_FOREGROUND=4 + # typeset -g POWERLEVEL9K_ASDF_JAVA_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_JAVA_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Perl version from asdf. + typeset -g POWERLEVEL9K_ASDF_PERL_FOREGROUND=6 + # typeset -g POWERLEVEL9K_ASDF_PERL_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_PERL_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Erlang version from asdf. + typeset -g POWERLEVEL9K_ASDF_ERLANG_FOREGROUND=1 + # typeset -g POWERLEVEL9K_ASDF_ERLANG_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_ERLANG_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Elixir version from asdf. + typeset -g POWERLEVEL9K_ASDF_ELIXIR_FOREGROUND=5 + # typeset -g POWERLEVEL9K_ASDF_ELIXIR_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_ELIXIR_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Postgres version from asdf. + typeset -g POWERLEVEL9K_ASDF_POSTGRES_FOREGROUND=6 + # typeset -g POWERLEVEL9K_ASDF_POSTGRES_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_POSTGRES_SHOW_ON_UPGLOB='*.foo|*.bar' + + # PHP version from asdf. + typeset -g POWERLEVEL9K_ASDF_PHP_FOREGROUND=5 + # typeset -g POWERLEVEL9K_ASDF_PHP_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_PHP_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Haskell version from asdf. + typeset -g POWERLEVEL9K_ASDF_HASKELL_FOREGROUND=3 + # typeset -g POWERLEVEL9K_ASDF_HASKELL_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_HASKELL_SHOW_ON_UPGLOB='*.foo|*.bar' + + # Julia version from asdf. + typeset -g POWERLEVEL9K_ASDF_JULIA_FOREGROUND=2 + # typeset -g POWERLEVEL9K_ASDF_JULIA_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_ASDF_JULIA_SHOW_ON_UPGLOB='*.foo|*.bar' + + ##########[ nordvpn: nordvpn connection status, linux only (https://nordvpn.com/) ]########### + # NordVPN connection indicator color. + typeset -g POWERLEVEL9K_NORDVPN_FOREGROUND=6 + # Hide NordVPN connection indicator when not connected. + typeset -g POWERLEVEL9K_NORDVPN_{DISCONNECTED,CONNECTING,DISCONNECTING}_CONTENT_EXPANSION= + typeset -g POWERLEVEL9K_NORDVPN_{DISCONNECTED,CONNECTING,DISCONNECTING}_VISUAL_IDENTIFIER_EXPANSION= + # Custom icon. + typeset -g POWERLEVEL9K_NORDVPN_VISUAL_IDENTIFIER_EXPANSION='nord' + + #################[ ranger: ranger shell (https://github.com/ranger/ranger) ]################## + # Ranger shell color. + typeset -g POWERLEVEL9K_RANGER_FOREGROUND=3 + # Custom icon. + typeset -g POWERLEVEL9K_RANGER_VISUAL_IDENTIFIER_EXPANSION='▲' + + ######################[ nnn: nnn shell (https://github.com/jarun/nnn) ]####################### + # Nnn shell color. + typeset -g POWERLEVEL9K_NNN_FOREGROUND=3 + # Custom icon. + # typeset -g POWERLEVEL9K_NNN_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######################[ lf: lf shell (https://github.com/gokcehan/lf) ]####################### + # lf shell color. + typeset -g POWERLEVEL9K_LF_FOREGROUND=3 + # Custom icon. + # typeset -g POWERLEVEL9K_LF_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##################[ xplr: xplr shell (https://github.com/sayanarijit/xplr) ]################## + # xplr shell color. + typeset -g POWERLEVEL9K_XPLR_FOREGROUND=3 + # Custom icon. + # typeset -g POWERLEVEL9K_XPLR_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########################[ vim_shell: vim shell indicator (:sh) ]########################### + # Vim shell indicator color. + typeset -g POWERLEVEL9K_VIM_SHELL_FOREGROUND=3 + # Custom icon. + # typeset -g POWERLEVEL9K_VIM_SHELL_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######[ midnight_commander: midnight commander shell (https://midnight-commander.org/) ]###### + # Midnight Commander shell color. + typeset -g POWERLEVEL9K_MIDNIGHT_COMMANDER_FOREGROUND=3 + # Custom icon. + # typeset -g POWERLEVEL9K_MIDNIGHT_COMMANDER_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #[ nix_shell: nix shell (https://nixos.org/nixos/nix-pills/developing-with-nix-shell.html) ]## + # Nix shell color. + typeset -g POWERLEVEL9K_NIX_SHELL_FOREGROUND=4 + + # Display the icon of nix_shell if PATH contains a subdirectory of /nix/store. + # typeset -g POWERLEVEL9K_NIX_SHELL_INFER_FROM_PATH=false + + # Tip: If you want to see just the icon without "pure" and "impure", uncomment the next line. + # typeset -g POWERLEVEL9K_NIX_SHELL_CONTENT_EXPANSION= + + # Custom icon. + # typeset -g POWERLEVEL9K_NIX_SHELL_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##################################[ disk_usage: disk usage ]################################## + # Colors for different levels of disk usage. + typeset -g POWERLEVEL9K_DISK_USAGE_NORMAL_FOREGROUND=2 + typeset -g POWERLEVEL9K_DISK_USAGE_WARNING_FOREGROUND=3 + typeset -g POWERLEVEL9K_DISK_USAGE_CRITICAL_FOREGROUND=1 + # Thresholds for different levels of disk usage (percentage points). + typeset -g POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL=90 + typeset -g POWERLEVEL9K_DISK_USAGE_CRITICAL_LEVEL=95 + # If set to true, hide disk usage when below $POWERLEVEL9K_DISK_USAGE_WARNING_LEVEL percent. + typeset -g POWERLEVEL9K_DISK_USAGE_ONLY_WARNING=false + # Custom icon. + # typeset -g POWERLEVEL9K_DISK_USAGE_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######################################[ ram: free RAM ]####################################### + # RAM color. + typeset -g POWERLEVEL9K_RAM_FOREGROUND=2 + # Custom icon. + # typeset -g POWERLEVEL9K_RAM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #####################################[ swap: used swap ]###################################### + # Swap color. + typeset -g POWERLEVEL9K_SWAP_FOREGROUND=3 + # Custom icon. + # typeset -g POWERLEVEL9K_SWAP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ######################################[ load: CPU load ]###################################### + # Show average CPU load over this many last minutes. Valid values are 1, 5 and 15. + typeset -g POWERLEVEL9K_LOAD_WHICH=5 + # Load color when load is under 50%. + typeset -g POWERLEVEL9K_LOAD_NORMAL_FOREGROUND=2 + # Load color when load is between 50% and 70%. + typeset -g POWERLEVEL9K_LOAD_WARNING_FOREGROUND=3 + # Load color when load is over 70%. + typeset -g POWERLEVEL9K_LOAD_CRITICAL_FOREGROUND=1 + # Custom icon. + # typeset -g POWERLEVEL9K_LOAD_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################[ todo: todo items (https://github.com/todotxt/todo.txt-cli) ]################ + # Todo color. + typeset -g POWERLEVEL9K_TODO_FOREGROUND=4 + # Hide todo when the total number of tasks is zero. + typeset -g POWERLEVEL9K_TODO_HIDE_ZERO_TOTAL=true + # Hide todo when the number of tasks after filtering is zero. + typeset -g POWERLEVEL9K_TODO_HIDE_ZERO_FILTERED=false + + # Todo format. The following parameters are available within the expansion. + # + # - P9K_TODO_TOTAL_TASK_COUNT The total number of tasks. + # - P9K_TODO_FILTERED_TASK_COUNT The number of tasks after filtering. + # + # These variables correspond to the last line of the output of `todo.sh -p ls`: + # + # TODO: 24 of 42 tasks shown + # + # Here 24 is P9K_TODO_FILTERED_TASK_COUNT and 42 is P9K_TODO_TOTAL_TASK_COUNT. + # + # typeset -g POWERLEVEL9K_TODO_CONTENT_EXPANSION='$P9K_TODO_FILTERED_TASK_COUNT' + + # Custom icon. + # typeset -g POWERLEVEL9K_TODO_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ timewarrior: timewarrior tracking status (https://timewarrior.net/) ]############ + # Timewarrior color. + typeset -g POWERLEVEL9K_TIMEWARRIOR_FOREGROUND=4 + # If the tracked task is longer than 24 characters, truncate and append "…". + # Tip: To always display tasks without truncation, delete the following parameter. + # Tip: To hide task names and display just the icon when time tracking is enabled, set the + # value of the following parameter to "". + typeset -g POWERLEVEL9K_TIMEWARRIOR_CONTENT_EXPANSION='${P9K_CONTENT:0:24}${${P9K_CONTENT:24}:+…}' + + # Custom icon. + # typeset -g POWERLEVEL9K_TIMEWARRIOR_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##############[ taskwarrior: taskwarrior task count (https://taskwarrior.org/) ]############## + # Taskwarrior color. + typeset -g POWERLEVEL9K_TASKWARRIOR_FOREGROUND=6 + + # Taskwarrior segment format. The following parameters are available within the expansion. + # + # - P9K_TASKWARRIOR_PENDING_COUNT The number of pending tasks: `task +PENDING count`. + # - P9K_TASKWARRIOR_OVERDUE_COUNT The number of overdue tasks: `task +OVERDUE count`. + # + # Zero values are represented as empty parameters. + # + # The default format: + # + # '${P9K_TASKWARRIOR_OVERDUE_COUNT:+"!$P9K_TASKWARRIOR_OVERDUE_COUNT/"}$P9K_TASKWARRIOR_PENDING_COUNT' + # + # typeset -g POWERLEVEL9K_TASKWARRIOR_CONTENT_EXPANSION='$P9K_TASKWARRIOR_PENDING_COUNT' + + # Custom icon. + # typeset -g POWERLEVEL9K_TASKWARRIOR_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################################[ cpu_arch: CPU architecture ]################################ + # CPU architecture color. + typeset -g POWERLEVEL9K_CPU_ARCH_FOREGROUND=3 + + # Hide the segment when on a specific CPU architecture. + # typeset -g POWERLEVEL9K_CPU_ARCH_X86_64_CONTENT_EXPANSION= + # typeset -g POWERLEVEL9K_CPU_ARCH_X86_64_VISUAL_IDENTIFIER_EXPANSION= + + # Custom icon. + # typeset -g POWERLEVEL9K_CPU_ARCH_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##################################[ context: user@hostname ]################################## + # Context color when running with privileges. + typeset -g POWERLEVEL9K_CONTEXT_ROOT_FOREGROUND=1 + # Context color in SSH without privileges. + typeset -g POWERLEVEL9K_CONTEXT_{REMOTE,REMOTE_SUDO}_FOREGROUND=7 + # Default context color (no privileges, no SSH). + typeset -g POWERLEVEL9K_CONTEXT_FOREGROUND=7 + + # Context format when running with privileges: bold user@hostname. + typeset -g POWERLEVEL9K_CONTEXT_ROOT_TEMPLATE='%B%n@%m' + # Context format when in SSH without privileges: user@hostname. + typeset -g POWERLEVEL9K_CONTEXT_{REMOTE,REMOTE_SUDO}_TEMPLATE='%n@%m' + # Default context format (no privileges, no SSH): user@hostname. + typeset -g POWERLEVEL9K_CONTEXT_TEMPLATE='%n@%m' + + # Don't show context unless running with privileges or in SSH. + # Tip: Remove the next line to always show context. + typeset -g POWERLEVEL9K_CONTEXT_{DEFAULT,SUDO}_{CONTENT,VISUAL_IDENTIFIER}_EXPANSION= + + # Custom icon. + # typeset -g POWERLEVEL9K_CONTEXT_VISUAL_IDENTIFIER_EXPANSION='⭐' + # Custom prefix. + typeset -g POWERLEVEL9K_CONTEXT_PREFIX='%fwith ' + + ###[ virtualenv: python virtual environment (https://docs.python.org/3/library/venv.html) ]### + # Python virtual environment color. + typeset -g POWERLEVEL9K_VIRTUALENV_FOREGROUND=6 + # Don't show Python version next to the virtual environment name. + typeset -g POWERLEVEL9K_VIRTUALENV_SHOW_PYTHON_VERSION=false + # If set to "false", won't show virtualenv if pyenv is already shown. + # If set to "if-different", won't show virtualenv if it's the same as pyenv. + typeset -g POWERLEVEL9K_VIRTUALENV_SHOW_WITH_PYENV=false + # Separate environment name from Python version only with a space. + typeset -g POWERLEVEL9K_VIRTUALENV_{LEFT,RIGHT}_DELIMITER= + # Custom icon. + # typeset -g POWERLEVEL9K_VIRTUALENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #####################[ anaconda: conda environment (https://conda.io/) ]###################### + # Anaconda environment color. + typeset -g POWERLEVEL9K_ANACONDA_FOREGROUND=6 + + # Anaconda segment format. The following parameters are available within the expansion. + # + # - CONDA_PREFIX Absolute path to the active Anaconda/Miniconda environment. + # - CONDA_DEFAULT_ENV Name of the active Anaconda/Miniconda environment. + # - CONDA_PROMPT_MODIFIER Configurable prompt modifier (see below). + # - P9K_ANACONDA_PYTHON_VERSION Current python version (python --version). + # + # CONDA_PROMPT_MODIFIER can be configured with the following command: + # + # conda config --set env_prompt '({default_env}) ' + # + # The last argument is a Python format string that can use the following variables: + # + # - prefix The same as CONDA_PREFIX. + # - default_env The same as CONDA_DEFAULT_ENV. + # - name The last segment of CONDA_PREFIX. + # - stacked_env Comma-separated list of names in the environment stack. The first element is + # always the same as default_env. + # + # Note: '({default_env}) ' is the default value of env_prompt. + # + # The default value of POWERLEVEL9K_ANACONDA_CONTENT_EXPANSION expands to $CONDA_PROMPT_MODIFIER + # without the surrounding parentheses, or to the last path component of CONDA_PREFIX if the former + # is empty. + typeset -g POWERLEVEL9K_ANACONDA_CONTENT_EXPANSION='${${${${CONDA_PROMPT_MODIFIER#\(}% }%\)}:-${CONDA_PREFIX:t}}' + + # Custom icon. + # typeset -g POWERLEVEL9K_ANACONDA_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################[ pyenv: python environment (https://github.com/pyenv/pyenv) ]################ + # Pyenv color. + typeset -g POWERLEVEL9K_PYENV_FOREGROUND=6 + # Hide python version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_PYENV_SOURCES=(shell local global) + # If set to false, hide python version if it's the same as global: + # $(pyenv version-name) == $(pyenv global). + typeset -g POWERLEVEL9K_PYENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide python version if it's equal to "system". + typeset -g POWERLEVEL9K_PYENV_SHOW_SYSTEM=true + + # Pyenv segment format. The following parameters are available within the expansion. + # + # - P9K_CONTENT Current pyenv environment (pyenv version-name). + # - P9K_PYENV_PYTHON_VERSION Current python version (python --version). + # + # The default format has the following logic: + # + # 1. Display just "$P9K_CONTENT" if it's equal to "$P9K_PYENV_PYTHON_VERSION" or + # starts with "$P9K_PYENV_PYTHON_VERSION/". + # 2. Otherwise display "$P9K_CONTENT $P9K_PYENV_PYTHON_VERSION". + typeset -g POWERLEVEL9K_PYENV_CONTENT_EXPANSION='${P9K_CONTENT}${${P9K_CONTENT:#$P9K_PYENV_PYTHON_VERSION(|/*)}:+ $P9K_PYENV_PYTHON_VERSION}' + + # Custom icon. + # typeset -g POWERLEVEL9K_PYENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################[ goenv: go environment (https://github.com/syndbg/goenv) ]################ + # Goenv color. + typeset -g POWERLEVEL9K_GOENV_FOREGROUND=6 + # Hide go version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_GOENV_SOURCES=(shell local global) + # If set to false, hide go version if it's the same as global: + # $(goenv version-name) == $(goenv global). + typeset -g POWERLEVEL9K_GOENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide go version if it's equal to "system". + typeset -g POWERLEVEL9K_GOENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_GOENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ nodenv: node.js version from nodenv (https://github.com/nodenv/nodenv) ]########## + # Nodenv color. + typeset -g POWERLEVEL9K_NODENV_FOREGROUND=2 + # Hide node version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_NODENV_SOURCES=(shell local global) + # If set to false, hide node version if it's the same as global: + # $(nodenv version-name) == $(nodenv global). + typeset -g POWERLEVEL9K_NODENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide node version if it's equal to "system". + typeset -g POWERLEVEL9K_NODENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_NODENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##############[ nvm: node.js version from nvm (https://github.com/nvm-sh/nvm) ]############### + # Nvm color. + typeset -g POWERLEVEL9K_NVM_FOREGROUND=2 + # If set to false, hide node version if it's the same as default: + # $(nvm version current) == $(nvm version default). + typeset -g POWERLEVEL9K_NVM_PROMPT_ALWAYS_SHOW=false + # If set to false, hide node version if it's equal to "system". + typeset -g POWERLEVEL9K_NVM_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_NVM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ############[ nodeenv: node.js environment (https://github.com/ekalinin/nodeenv) ]############ + # Nodeenv color. + typeset -g POWERLEVEL9K_NODEENV_FOREGROUND=2 + # Don't show Node version next to the environment name. + typeset -g POWERLEVEL9K_NODEENV_SHOW_NODE_VERSION=false + # Separate environment name from Node version only with a space. + typeset -g POWERLEVEL9K_NODEENV_{LEFT,RIGHT}_DELIMITER= + # Custom icon. + # typeset -g POWERLEVEL9K_NODEENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##############################[ node_version: node.js version ]############################### + # Node version color. + typeset -g POWERLEVEL9K_NODE_VERSION_FOREGROUND=2 + # Show node version only when in a directory tree containing package.json. + typeset -g POWERLEVEL9K_NODE_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_NODE_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #######################[ go_version: go version (https://golang.org) ]######################## + # Go version color. + typeset -g POWERLEVEL9K_GO_VERSION_FOREGROUND=6 + # Show go version only when in a go project subdirectory. + typeset -g POWERLEVEL9K_GO_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_GO_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #################[ rust_version: rustc version (https://www.rust-lang.org) ]################## + # Rust version color. + typeset -g POWERLEVEL9K_RUST_VERSION_FOREGROUND=4 + # Show rust version only when in a rust project subdirectory. + typeset -g POWERLEVEL9K_RUST_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_RUST_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###############[ dotnet_version: .NET version (https://dotnet.microsoft.com) ]################ + # .NET version color. + typeset -g POWERLEVEL9K_DOTNET_VERSION_FOREGROUND=5 + # Show .NET version only when in a .NET project subdirectory. + typeset -g POWERLEVEL9K_DOTNET_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_DOTNET_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #####################[ php_version: php version (https://www.php.net/) ]###################### + # PHP version color. + typeset -g POWERLEVEL9K_PHP_VERSION_FOREGROUND=5 + # Show PHP version only when in a PHP project subdirectory. + typeset -g POWERLEVEL9K_PHP_VERSION_PROJECT_ONLY=true + # Custom icon. + # typeset -g POWERLEVEL9K_PHP_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ laravel_version: laravel php framework version (https://laravel.com/) ]########### + # Laravel version color. + typeset -g POWERLEVEL9K_LARAVEL_VERSION_FOREGROUND=1 + # Custom icon. + # typeset -g POWERLEVEL9K_LARAVEL_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ####################[ java_version: java version (https://www.java.com/) ]#################### + # Java version color. + typeset -g POWERLEVEL9K_JAVA_VERSION_FOREGROUND=4 + # Show java version only when in a java project subdirectory. + typeset -g POWERLEVEL9K_JAVA_VERSION_PROJECT_ONLY=true + # Show brief version. + typeset -g POWERLEVEL9K_JAVA_VERSION_FULL=false + # Custom icon. + # typeset -g POWERLEVEL9K_JAVA_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###[ package: name@version from package.json (https://docs.npmjs.com/files/package.json) ]#### + # Package color. + typeset -g POWERLEVEL9K_PACKAGE_FOREGROUND=6 + # Package format. The following parameters are available within the expansion. + # + # - P9K_PACKAGE_NAME The value of `name` field in package.json. + # - P9K_PACKAGE_VERSION The value of `version` field in package.json. + # + # typeset -g POWERLEVEL9K_PACKAGE_CONTENT_EXPANSION='${P9K_PACKAGE_NAME//\%/%%}@${P9K_PACKAGE_VERSION//\%/%%}' + # Custom icon. + # typeset -g POWERLEVEL9K_PACKAGE_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #############[ rbenv: ruby version from rbenv (https://github.com/rbenv/rbenv) ]############## + # Rbenv color. + typeset -g POWERLEVEL9K_RBENV_FOREGROUND=1 + # Hide ruby version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_RBENV_SOURCES=(shell local global) + # If set to false, hide ruby version if it's the same as global: + # $(rbenv version-name) == $(rbenv global). + typeset -g POWERLEVEL9K_RBENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide ruby version if it's equal to "system". + typeset -g POWERLEVEL9K_RBENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_RBENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #######################[ rvm: ruby version from rvm (https://rvm.io) ]######################## + # Rvm color. + typeset -g POWERLEVEL9K_RVM_FOREGROUND=1 + # Don't show @gemset at the end. + typeset -g POWERLEVEL9K_RVM_SHOW_GEMSET=false + # Don't show ruby- at the front. + typeset -g POWERLEVEL9K_RVM_SHOW_PREFIX=false + # Custom icon. + # typeset -g POWERLEVEL9K_RVM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ fvm: flutter version management (https://github.com/leoafarias/fvm) ]############ + # Fvm color. + typeset -g POWERLEVEL9K_FVM_FOREGROUND=4 + # Custom icon. + # typeset -g POWERLEVEL9K_FVM_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ luaenv: lua version from luaenv (https://github.com/cehoffman/luaenv) ]########### + # Lua color. + typeset -g POWERLEVEL9K_LUAENV_FOREGROUND=4 + # Hide lua version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_LUAENV_SOURCES=(shell local global) + # If set to false, hide lua version if it's the same as global: + # $(luaenv version-name) == $(luaenv global). + typeset -g POWERLEVEL9K_LUAENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide lua version if it's equal to "system". + typeset -g POWERLEVEL9K_LUAENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_LUAENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###############[ jenv: java version from jenv (https://github.com/jenv/jenv) ]################ + # Java color. + typeset -g POWERLEVEL9K_JENV_FOREGROUND=4 + # Hide java version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_JENV_SOURCES=(shell local global) + # If set to false, hide java version if it's the same as global: + # $(jenv version-name) == $(jenv global). + typeset -g POWERLEVEL9K_JENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide java version if it's equal to "system". + typeset -g POWERLEVEL9K_JENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_JENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ plenv: perl version from plenv (https://github.com/tokuhirom/plenv) ]############ + # Perl color. + typeset -g POWERLEVEL9K_PLENV_FOREGROUND=6 + # Hide perl version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_PLENV_SOURCES=(shell local global) + # If set to false, hide perl version if it's the same as global: + # $(plenv version-name) == $(plenv global). + typeset -g POWERLEVEL9K_PLENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide perl version if it's equal to "system". + typeset -g POWERLEVEL9K_PLENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_PLENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ perlbrew: perl version from perlbrew (https://github.com/gugod/App-perlbrew) ]############ + # Perlbrew color. + typeset -g POWERLEVEL9K_PERLBREW_FOREGROUND=67 + # Show perlbrew version only when in a perl project subdirectory. + typeset -g POWERLEVEL9K_PERLBREW_PROJECT_ONLY=true + # Don't show "perl-" at the front. + typeset -g POWERLEVEL9K_PERLBREW_SHOW_PREFIX=false + # Custom icon. + # typeset -g POWERLEVEL9K_PERLBREW_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ############[ phpenv: php version from phpenv (https://github.com/phpenv/phpenv) ]############ + # PHP color. + typeset -g POWERLEVEL9K_PHPENV_FOREGROUND=5 + # Hide php version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_PHPENV_SOURCES=(shell local global) + # If set to false, hide php version if it's the same as global: + # $(phpenv version-name) == $(phpenv global). + typeset -g POWERLEVEL9K_PHPENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide php version if it's equal to "system". + typeset -g POWERLEVEL9K_PHPENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_PHPENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #######[ scalaenv: scala version from scalaenv (https://github.com/scalaenv/scalaenv) ]####### + # Scala color. + typeset -g POWERLEVEL9K_SCALAENV_FOREGROUND=1 + # Hide scala version if it doesn't come from one of these sources. + typeset -g POWERLEVEL9K_SCALAENV_SOURCES=(shell local global) + # If set to false, hide scala version if it's the same as global: + # $(scalaenv version-name) == $(scalaenv global). + typeset -g POWERLEVEL9K_SCALAENV_PROMPT_ALWAYS_SHOW=false + # If set to false, hide scala version if it's equal to "system". + typeset -g POWERLEVEL9K_SCALAENV_SHOW_SYSTEM=true + # Custom icon. + # typeset -g POWERLEVEL9K_SCALAENV_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ##########[ haskell_stack: haskell version from stack (https://haskellstack.org/) ]########### + # Haskell color. + typeset -g POWERLEVEL9K_HASKELL_STACK_FOREGROUND=3 + # Hide haskell version if it doesn't come from one of these sources. + # + # shell: version is set by STACK_YAML + # local: version is set by stack.yaml up the directory tree + # global: version is set by the implicit global project (~/.stack/global-project/stack.yaml) + typeset -g POWERLEVEL9K_HASKELL_STACK_SOURCES=(shell local) + # If set to false, hide haskell version if it's the same as in the implicit global project. + typeset -g POWERLEVEL9K_HASKELL_STACK_ALWAYS_SHOW=true + # Custom icon. + # typeset -g POWERLEVEL9K_HASKELL_STACK_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #############[ kubecontext: current kubernetes context (https://kubernetes.io/) ]############# + # Show kubecontext only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show kubecontext. + typeset -g POWERLEVEL9K_KUBECONTEXT_SHOW_ON_COMMAND='kubectl|helm|kubens|kubectx|oc|istioctl|kogito|k9s|helmfile|flux|fluxctl|stern|kubeseal|skaffold|kubent|kubecolor' + + # Kubernetes context classes for the purpose of using different colors, icons and expansions with + # different contexts. + # + # POWERLEVEL9K_KUBECONTEXT_CLASSES is an array with even number of elements. The first element + # in each pair defines a pattern against which the current kubernetes context gets matched. + # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) + # that gets matched. If you unset all POWERLEVEL9K_KUBECONTEXT_*CONTENT_EXPANSION parameters, + # you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_KUBECONTEXT_CLASSES defines the context class. Patterns are tried in order. The + # first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_KUBECONTEXT_CLASSES=( + # '*prod*' PROD + # '*test*' TEST + # '*' DEFAULT) + # + # If your current kubernetes context is "deathray-testing/default", its class is TEST + # because "deathray-testing/default" doesn't match the pattern '*prod*' but does match '*test*'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_FOREGROUND=3 + # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_KUBECONTEXT_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' + typeset -g POWERLEVEL9K_KUBECONTEXT_CLASSES=( + # '*prod*' PROD # These values are examples that are unlikely + # '*test*' TEST # to match your needs. Customize them as needed. + '*' DEFAULT) + typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_FOREGROUND=5 + typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='○' + + # Use POWERLEVEL9K_KUBECONTEXT_CONTENT_EXPANSION to specify the content displayed by kubecontext + # segment. Parameter expansions are very flexible and fast, too. See reference: + # http://zsh.sourceforge.net/Doc/Release/Expansion.html#Parameter-Expansion. + # + # Within the expansion the following parameters are always available: + # + # - P9K_CONTENT The content that would've been displayed if there was no content + # expansion defined. + # - P9K_KUBECONTEXT_NAME The current context's name. Corresponds to column NAME in the + # output of `kubectl config get-contexts`. + # - P9K_KUBECONTEXT_CLUSTER The current context's cluster. Corresponds to column CLUSTER in the + # output of `kubectl config get-contexts`. + # - P9K_KUBECONTEXT_NAMESPACE The current context's namespace. Corresponds to column NAMESPACE + # in the output of `kubectl config get-contexts`. If there is no + # namespace, the parameter is set to "default". + # - P9K_KUBECONTEXT_USER The current context's user. Corresponds to column AUTHINFO in the + # output of `kubectl config get-contexts`. + # + # If the context points to Google Kubernetes Engine (GKE) or Elastic Kubernetes Service (EKS), + # the following extra parameters are available: + # + # - P9K_KUBECONTEXT_CLOUD_NAME Either "gke" or "eks". + # - P9K_KUBECONTEXT_CLOUD_ACCOUNT Account/project ID. + # - P9K_KUBECONTEXT_CLOUD_ZONE Availability zone. + # - P9K_KUBECONTEXT_CLOUD_CLUSTER Cluster. + # + # P9K_KUBECONTEXT_CLOUD_* parameters are derived from P9K_KUBECONTEXT_CLUSTER. For example, + # if P9K_KUBECONTEXT_CLUSTER is "gke_my-account_us-east1-a_my-cluster-01": + # + # - P9K_KUBECONTEXT_CLOUD_NAME=gke + # - P9K_KUBECONTEXT_CLOUD_ACCOUNT=my-account + # - P9K_KUBECONTEXT_CLOUD_ZONE=us-east1-a + # - P9K_KUBECONTEXT_CLOUD_CLUSTER=my-cluster-01 + # + # If P9K_KUBECONTEXT_CLUSTER is "arn:aws:eks:us-east-1:123456789012:cluster/my-cluster-01": + # + # - P9K_KUBECONTEXT_CLOUD_NAME=eks + # - P9K_KUBECONTEXT_CLOUD_ACCOUNT=123456789012 + # - P9K_KUBECONTEXT_CLOUD_ZONE=us-east-1 + # - P9K_KUBECONTEXT_CLOUD_CLUSTER=my-cluster-01 + typeset -g POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION= + # Show P9K_KUBECONTEXT_CLOUD_CLUSTER if it's not empty and fall back to P9K_KUBECONTEXT_NAME. + POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION+='${P9K_KUBECONTEXT_CLOUD_CLUSTER:-${P9K_KUBECONTEXT_NAME}}' + # Append the current context's namespace if it's not "default". + POWERLEVEL9K_KUBECONTEXT_DEFAULT_CONTENT_EXPANSION+='${${:-/$P9K_KUBECONTEXT_NAMESPACE}:#/default}' + + # Custom prefix. + typeset -g POWERLEVEL9K_KUBECONTEXT_PREFIX='%fat ' + + ################[ terraform: terraform workspace (https://www.terraform.io) ]################# + # Don't show terraform workspace if it's literally "default". + typeset -g POWERLEVEL9K_TERRAFORM_SHOW_DEFAULT=false + # POWERLEVEL9K_TERRAFORM_CLASSES is an array with even number of elements. The first element + # in each pair defines a pattern against which the current terraform workspace gets matched. + # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) + # that gets matched. If you unset all POWERLEVEL9K_TERRAFORM_*CONTENT_EXPANSION parameters, + # you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_TERRAFORM_CLASSES defines the workspace class. Patterns are tried in order. The + # first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_TERRAFORM_CLASSES=( + # '*prod*' PROD + # '*test*' TEST + # '*' OTHER) + # + # If your current terraform workspace is "project_test", its class is TEST because "project_test" + # doesn't match the pattern '*prod*' but does match '*test*'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_TERRAFORM_TEST_FOREGROUND=2 + # typeset -g POWERLEVEL9K_TERRAFORM_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_TERRAFORM_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' + typeset -g POWERLEVEL9K_TERRAFORM_CLASSES=( + # '*prod*' PROD # These values are examples that are unlikely + # '*test*' TEST # to match your needs. Customize them as needed. + '*' OTHER) + typeset -g POWERLEVEL9K_TERRAFORM_OTHER_FOREGROUND=4 + # typeset -g POWERLEVEL9K_TERRAFORM_OTHER_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #############[ terraform_version: terraform version (https://www.terraform.io) ]############## + # Terraform version color. + typeset -g POWERLEVEL9K_TERRAFORM_VERSION_FOREGROUND=4 + # Custom icon. + # typeset -g POWERLEVEL9K_TERRAFORM_VERSION_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #[ aws: aws profile (https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-profiles.html) ]# + # Show aws only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show aws. + typeset -g POWERLEVEL9K_AWS_SHOW_ON_COMMAND='aws|awless|terraform|pulumi|terragrunt' + + # POWERLEVEL9K_AWS_CLASSES is an array with even number of elements. The first element + # in each pair defines a pattern against which the current AWS profile gets matched. + # More specifically, it's P9K_CONTENT prior to the application of context expansion (see below) + # that gets matched. If you unset all POWERLEVEL9K_AWS_*CONTENT_EXPANSION parameters, + # you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_AWS_CLASSES defines the profile class. Patterns are tried in order. The + # first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_AWS_CLASSES=( + # '*prod*' PROD + # '*test*' TEST + # '*' DEFAULT) + # + # If your current AWS profile is "company_test", its class is TEST + # because "company_test" doesn't match the pattern '*prod*' but does match '*test*'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_AWS_TEST_FOREGROUND=2 + # typeset -g POWERLEVEL9K_AWS_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_AWS_TEST_CONTENT_EXPANSION='> ${P9K_CONTENT} <' + typeset -g POWERLEVEL9K_AWS_CLASSES=( + # '*prod*' PROD # These values are examples that are unlikely + # '*test*' TEST # to match your needs. Customize them as needed. + '*' DEFAULT) + typeset -g POWERLEVEL9K_AWS_DEFAULT_FOREGROUND=3 + # typeset -g POWERLEVEL9K_AWS_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # AWS segment format. The following parameters are available within the expansion. + # + # - P9K_AWS_PROFILE The name of the current AWS profile. + # - P9K_AWS_REGION The region associated with the current AWS profile. + typeset -g POWERLEVEL9K_AWS_CONTENT_EXPANSION='${P9K_AWS_PROFILE//\%/%%}${P9K_AWS_REGION:+ ${P9K_AWS_REGION//\%/%%}}' + + #[ aws_eb_env: aws elastic beanstalk environment (https://aws.amazon.com/elasticbeanstalk/) ]# + # AWS Elastic Beanstalk environment color. + typeset -g POWERLEVEL9K_AWS_EB_ENV_FOREGROUND=2 + # Custom icon. + typeset -g POWERLEVEL9K_AWS_EB_ENV_VISUAL_IDENTIFIER_EXPANSION='eb' + + ##########[ azure: azure account name (https://docs.microsoft.com/en-us/cli/azure) ]########## + # Show azure only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show azure. + typeset -g POWERLEVEL9K_AZURE_SHOW_ON_COMMAND='az|terraform|pulumi|terragrunt' + # Azure account name color. + typeset -g POWERLEVEL9K_AZURE_FOREGROUND=4 + # Custom icon. + typeset -g POWERLEVEL9K_AZURE_VISUAL_IDENTIFIER_EXPANSION='az' + + ##########[ gcloud: google cloud account and project (https://cloud.google.com/) ]########### + # Show gcloud only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show gcloud. + typeset -g POWERLEVEL9K_GCLOUD_SHOW_ON_COMMAND='gcloud|gcs|gsutil' + # Google cloud color. + typeset -g POWERLEVEL9K_GCLOUD_FOREGROUND=4 + + # Google cloud format. Change the value of POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION and/or + # POWERLEVEL9K_GCLOUD_COMPLETE_CONTENT_EXPANSION if the default is too verbose or not informative + # enough. You can use the following parameters in the expansions. Each of them corresponds to the + # output of `gcloud` tool. + # + # Parameter | Source + # -------------------------|-------------------------------------------------------------------- + # P9K_GCLOUD_CONFIGURATION | gcloud config configurations list --format='value(name)' + # P9K_GCLOUD_ACCOUNT | gcloud config get-value account + # P9K_GCLOUD_PROJECT_ID | gcloud config get-value project + # P9K_GCLOUD_PROJECT_NAME | gcloud projects describe $P9K_GCLOUD_PROJECT_ID --format='value(name)' + # + # Note: ${VARIABLE//\%/%%} expands to ${VARIABLE} with all occurrences of '%' replaced with '%%'. + # + # Obtaining project name requires sending a request to Google servers. This can take a long time + # and even fail. When project name is unknown, P9K_GCLOUD_PROJECT_NAME is not set and gcloud + # prompt segment is in state PARTIAL. When project name gets known, P9K_GCLOUD_PROJECT_NAME gets + # set and gcloud prompt segment transitions to state COMPLETE. + # + # You can customize the format, icon and colors of gcloud segment separately for states PARTIAL + # and COMPLETE. You can also hide gcloud in state PARTIAL by setting + # POWERLEVEL9K_GCLOUD_PARTIAL_VISUAL_IDENTIFIER_EXPANSION and + # POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION to empty. + typeset -g POWERLEVEL9K_GCLOUD_PARTIAL_CONTENT_EXPANSION='${P9K_GCLOUD_PROJECT_ID//\%/%%}' + typeset -g POWERLEVEL9K_GCLOUD_COMPLETE_CONTENT_EXPANSION='${P9K_GCLOUD_PROJECT_NAME//\%/%%}' + + # Send a request to Google (by means of `gcloud projects describe ...`) to obtain project name + # this often. Negative value disables periodic polling. In this mode project name is retrieved + # only when the current configuration, account or project id changes. + typeset -g POWERLEVEL9K_GCLOUD_REFRESH_PROJECT_NAME_SECONDS=60 + + # Custom icon. + # typeset -g POWERLEVEL9K_GCLOUD_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #[ google_app_cred: google application credentials (https://cloud.google.com/docs/authentication/production) ]# + # Show google_app_cred only when the command you are typing invokes one of these tools. + # Tip: Remove the next line to always show google_app_cred. + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_SHOW_ON_COMMAND='terraform|pulumi|terragrunt' + + # Google application credentials classes for the purpose of using different colors, icons and + # expansions with different credentials. + # + # POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES is an array with even number of elements. The first + # element in each pair defines a pattern against which the current kubernetes context gets + # matched. More specifically, it's P9K_CONTENT prior to the application of context expansion + # (see below) that gets matched. If you unset all POWERLEVEL9K_GOOGLE_APP_CRED_*CONTENT_EXPANSION + # parameters, you'll see this value in your prompt. The second element of each pair in + # POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES defines the context class. Patterns are tried in order. + # The first match wins. + # + # For example, given these settings: + # + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES=( + # '*:*prod*:*' PROD + # '*:*test*:*' TEST + # '*' DEFAULT) + # + # If your current Google application credentials is "service_account deathray-testing x@y.com", + # its class is TEST because it doesn't match the pattern '* *prod* *' but does match '* *test* *'. + # + # You can define different colors, icons and content expansions for different classes: + # + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_FOREGROUND=3 + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_VISUAL_IDENTIFIER_EXPANSION='⭐' + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_TEST_CONTENT_EXPANSION='$P9K_GOOGLE_APP_CRED_PROJECT_ID' + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_CLASSES=( + # '*:*prod*:*' PROD # These values are examples that are unlikely + # '*:*test*:*' TEST # to match your needs. Customize them as needed. + '*' DEFAULT) + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_FOREGROUND=5 + # typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # Use POWERLEVEL9K_GOOGLE_APP_CRED_CONTENT_EXPANSION to specify the content displayed by + # google_app_cred segment. Parameter expansions are very flexible and fast, too. See reference: + # http://zsh.sourceforge.net/Doc/Release/Expansion.html#Parameter-Expansion. + # + # You can use the following parameters in the expansion. Each of them corresponds to one of the + # fields in the JSON file pointed to by GOOGLE_APPLICATION_CREDENTIALS. + # + # Parameter | JSON key file field + # ---------------------------------+--------------- + # P9K_GOOGLE_APP_CRED_TYPE | type + # P9K_GOOGLE_APP_CRED_PROJECT_ID | project_id + # P9K_GOOGLE_APP_CRED_CLIENT_EMAIL | client_email + # + # Note: ${VARIABLE//\%/%%} expands to ${VARIABLE} with all occurrences of '%' replaced by '%%'. + typeset -g POWERLEVEL9K_GOOGLE_APP_CRED_DEFAULT_CONTENT_EXPANSION='${P9K_GOOGLE_APP_CRED_PROJECT_ID//\%/%%}' + + ##############[ toolbox: toolbox name (https://github.com/containers/toolbox) ]############### + # Toolbox color. + typeset -g POWERLEVEL9K_TOOLBOX_FOREGROUND=3 + # Don't display the name of the toolbox if it matches fedora-toolbox-*. + typeset -g POWERLEVEL9K_TOOLBOX_CONTENT_EXPANSION='${P9K_TOOLBOX_NAME:#fedora-toolbox-*}' + # Custom icon. + # typeset -g POWERLEVEL9K_TOOLBOX_VISUAL_IDENTIFIER_EXPANSION='⭐' + # Custom prefix. + typeset -g POWERLEVEL9K_TOOLBOX_PREFIX='%fin ' + + ###############################[ public_ip: public IP address ]############################### + # Public IP color. + typeset -g POWERLEVEL9K_PUBLIC_IP_FOREGROUND=6 + # Custom icon. + # typeset -g POWERLEVEL9K_PUBLIC_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ########################[ vpn_ip: virtual private network indicator ]######################### + # VPN IP color. + typeset -g POWERLEVEL9K_VPN_IP_FOREGROUND=3 + # When on VPN, show just an icon without the IP address. + # Tip: To display the private IP address when on VPN, remove the next line. + typeset -g POWERLEVEL9K_VPN_IP_CONTENT_EXPANSION= + # Regular expression for the VPN network interface. Run `ifconfig` or `ip -4 a show` while on VPN + # to see the name of the interface. + typeset -g POWERLEVEL9K_VPN_IP_INTERFACE='(gpd|wg|(.*tun)|tailscale)[0-9]*|(zt.*)' + # If set to true, show one segment per matching network interface. If set to false, show only + # one segment corresponding to the first matching network interface. + # Tip: If you set it to true, you'll probably want to unset POWERLEVEL9K_VPN_IP_CONTENT_EXPANSION. + typeset -g POWERLEVEL9K_VPN_IP_SHOW_ALL=false + # Custom icon. + # typeset -g POWERLEVEL9K_VPN_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ###########[ ip: ip address and bandwidth usage for a specified network interface ]########### + # IP color. + typeset -g POWERLEVEL9K_IP_FOREGROUND=4 + # The following parameters are accessible within the expansion: + # + # Parameter | Meaning + # ----------------------+------------------------------------------- + # P9K_IP_IP | IP address + # P9K_IP_INTERFACE | network interface + # P9K_IP_RX_BYTES | total number of bytes received + # P9K_IP_TX_BYTES | total number of bytes sent + # P9K_IP_RX_BYTES_DELTA | number of bytes received since last prompt + # P9K_IP_TX_BYTES_DELTA | number of bytes sent since last prompt + # P9K_IP_RX_RATE | receive rate (since last prompt) + # P9K_IP_TX_RATE | send rate (since last prompt) + typeset -g POWERLEVEL9K_IP_CONTENT_EXPANSION='$P9K_IP_IP${P9K_IP_RX_RATE:+ %2F⇣$P9K_IP_RX_RATE}${P9K_IP_TX_RATE:+ %3F⇡$P9K_IP_TX_RATE}' + # Show information for the first network interface whose name matches this regular expression. + # Run `ifconfig` or `ip -4 a show` to see the names of all network interfaces. + typeset -g POWERLEVEL9K_IP_INTERFACE='[ew].*' + # Custom icon. + # typeset -g POWERLEVEL9K_IP_VISUAL_IDENTIFIER_EXPANSION='⭐' + + #########################[ proxy: system-wide http/https/ftp proxy ]########################## + # Proxy color. + typeset -g POWERLEVEL9K_PROXY_FOREGROUND=2 + # Custom icon. + # typeset -g POWERLEVEL9K_PROXY_VISUAL_IDENTIFIER_EXPANSION='⭐' + + ################################[ battery: internal battery ]################################# + # Show battery in red when it's below this level and not connected to power supply. + typeset -g POWERLEVEL9K_BATTERY_LOW_THRESHOLD=20 + typeset -g POWERLEVEL9K_BATTERY_LOW_FOREGROUND=1 + # Show battery in green when it's charging or fully charged. + typeset -g POWERLEVEL9K_BATTERY_{CHARGING,CHARGED}_FOREGROUND=2 + # Show battery in yellow when it's discharging. + typeset -g POWERLEVEL9K_BATTERY_DISCONNECTED_FOREGROUND=3 + # Battery pictograms going from low to high level of charge. + typeset -g POWERLEVEL9K_BATTERY_STAGES=('%K{0}▁' '%K{0}▂' '%K{0}▃' '%K{0}▄' '%K{0}▅' '%K{0}▆' '%K{0}▇' '%K{0}█') + # Don't show the remaining time to charge/discharge. + typeset -g POWERLEVEL9K_BATTERY_VERBOSE=false + + #####################################[ wifi: wifi speed ]##################################### + # WiFi color. + typeset -g POWERLEVEL9K_WIFI_FOREGROUND=4 + # Custom icon. + # typeset -g POWERLEVEL9K_WIFI_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # Use different colors and icons depending on signal strength ($P9K_WIFI_BARS). + # + # # Wifi colors and icons for different signal strength levels (low to high). + # typeset -g my_wifi_fg=(4 4 4 4 4) # <-- change these values + # typeset -g my_wifi_icon=('WiFi' 'WiFi' 'WiFi' 'WiFi' 'WiFi') # <-- change these values + # + # typeset -g POWERLEVEL9K_WIFI_CONTENT_EXPANSION='%F{${my_wifi_fg[P9K_WIFI_BARS+1]}}$P9K_WIFI_LAST_TX_RATE Mbps' + # typeset -g POWERLEVEL9K_WIFI_VISUAL_IDENTIFIER_EXPANSION='%F{${my_wifi_fg[P9K_WIFI_BARS+1]}}${my_wifi_icon[P9K_WIFI_BARS+1]}' + # + # The following parameters are accessible within the expansions: + # + # Parameter | Meaning + # ----------------------+--------------- + # P9K_WIFI_SSID | service set identifier, a.k.a. network name + # P9K_WIFI_LINK_AUTH | authentication protocol such as "wpa2-psk" or "none"; empty if unknown + # P9K_WIFI_LAST_TX_RATE | wireless transmit rate in megabits per second + # P9K_WIFI_RSSI | signal strength in dBm, from -120 to 0 + # P9K_WIFI_NOISE | noise in dBm, from -120 to 0 + # P9K_WIFI_BARS | signal strength in bars, from 0 to 4 (derived from P9K_WIFI_RSSI and P9K_WIFI_NOISE) + + ####################################[ time: current time ]#################################### + # Current time color. + typeset -g POWERLEVEL9K_TIME_FOREGROUND=6 + # Format for the current time: 09:51:02. See `man 3 strftime`. + typeset -g POWERLEVEL9K_TIME_FORMAT='%D{%I:%M:%S %p}' + # If set to true, time will update when you hit enter. This way prompts for the past + # commands will contain the start times of their commands as opposed to the default + # behavior where they contain the end times of their preceding commands. + typeset -g POWERLEVEL9K_TIME_UPDATE_ON_COMMAND=false + # Custom icon. + typeset -g POWERLEVEL9K_TIME_VISUAL_IDENTIFIER_EXPANSION= + # Custom prefix. + typeset -g POWERLEVEL9K_TIME_PREFIX='%fat ' + + # Example of a user-defined prompt segment. Function prompt_example will be called on every + # prompt if `example` prompt segment is added to POWERLEVEL9K_LEFT_PROMPT_ELEMENTS or + # POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS. It displays an icon and green text greeting the user. + # + # Type `p10k help segment` for documentation and a more sophisticated example. + function prompt_example() { + p10k segment -f 2 -i '⭐' -t 'hello, %n' + } + + # User-defined prompt segments may optionally provide an instant_prompt_* function. Its job + # is to generate the prompt segment for display in instant prompt. See + # https://github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt. + # + # Powerlevel10k will call instant_prompt_* at the same time as the regular prompt_* function + # and will record all `p10k segment` calls it makes. When displaying instant prompt, Powerlevel10k + # will replay these calls without actually calling instant_prompt_*. It is imperative that + # instant_prompt_* always makes the same `p10k segment` calls regardless of environment. If this + # rule is not observed, the content of instant prompt will be incorrect. + # + # Usually, you should either not define instant_prompt_* or simply call prompt_* from it. If + # instant_prompt_* is not defined for a segment, the segment won't be shown in instant prompt. + function instant_prompt_example() { + # Since prompt_example always makes the same `p10k segment` calls, we can call it from + # instant_prompt_example. This will give us the same `example` prompt segment in the instant + # and regular prompts. + prompt_example + } + + # User-defined prompt segments can be customized the same way as built-in segments. + # typeset -g POWERLEVEL9K_EXAMPLE_FOREGROUND=208 + # typeset -g POWERLEVEL9K_EXAMPLE_VISUAL_IDENTIFIER_EXPANSION='⭐' + + # Transient prompt works similarly to the builtin transient_rprompt option. It trims down prompt + # when accepting a command line. Supported values: + # + # - off: Don't change prompt when accepting a command line. + # - always: Trim down prompt when accepting a command line. + # - same-dir: Trim down prompt when accepting a command line unless this is the first command + # typed after changing current working directory. + typeset -g POWERLEVEL9K_TRANSIENT_PROMPT=always + + # Instant prompt mode. + # + # - off: Disable instant prompt. Choose this if you've tried instant prompt and found + # it incompatible with your zsh configuration files. + # - quiet: Enable instant prompt and don't print warnings when detecting console output + # during zsh initialization. Choose this if you've read and understood + # https://github.com/romkatv/powerlevel10k/blob/master/README.md#instant-prompt. + # - verbose: Enable instant prompt and print a warning when detecting console output during + # zsh initialization. Choose this if you've never tried instant prompt, haven't + # seen the warning, or if you are unsure what this all means. + typeset -g POWERLEVEL9K_INSTANT_PROMPT=verbose + + # Hot reload allows you to change POWERLEVEL9K options after Powerlevel10k has been initialized. + # For example, you can type POWERLEVEL9K_BACKGROUND=red and see your prompt turn red. Hot reload + # can slow down prompt by 1-2 milliseconds, so it's better to keep it turned off unless you + # really need it. + typeset -g POWERLEVEL9K_DISABLE_HOT_RELOAD=true + + # If p10k is already loaded, reload configuration. + # This works even with POWERLEVEL9K_DISABLE_HOT_RELOAD=true. + ((!$+functions[p10k])) || p10k reload } # Tell `p10k configure` which file it should overwrite. typeset -g POWERLEVEL9K_CONFIG_FILE=${${(%):-%x}:a} -(( ${#p10k_config_opts} )) && setopt ${p10k_config_opts[@]} +((${#p10k_config_opts})) && setopt ${p10k_config_opts[@]} 'builtin' 'unset' 'p10k_config_opts'