feat: add the --update option to the config command which causes all config options passed to fastanime to be persisted to your config file

This commit is contained in:
Benex254
2024-09-14 20:02:58 +03:00
parent 1c1c2457e8
commit 343bdba31b
5 changed files with 39 additions and 40 deletions

View File

@@ -145,7 +145,7 @@ signal.signal(signal.SIGINT, handle_exit)
type=click.Path(),
)
@click.option(
"--use-mpv-mod/--use-default-player", help="Whether to use python-mpv", type=bool
"--use-python-mpv/--use-default-player", help="Whether to use python-mpv", type=bool
)
@click.option("--sync-play", "-sp", help="Use sync play", is_flag=True)
@click.pass_context
@@ -179,7 +179,7 @@ def run_cli(
rofi_theme,
rofi_theme_confirm,
rofi_theme_input,
use_mpv_mod,
use_python_mpv,
sync_play,
):
from .config import Config
@@ -260,10 +260,10 @@ def run_cli(
):
ctx.obj.auto_select = auto_select
if (
ctx.get_parameter_source("use_mpv_mod")
ctx.get_parameter_source("use_python_mpv")
== click.core.ParameterSource.COMMANDLINE
):
ctx.obj.use_mpv_mod = use_mpv_mod
ctx.obj.use_mpv_mod = use_python_mpv
if downloads_dir:
ctx.obj.downloads_dir = downloads_dir
if translation_type:

View File

@@ -7,7 +7,7 @@ if TYPE_CHECKING:
@click.command(
help="Opens up your fastanime config in your preferred editor",
help="Manage your config with ease",
short_help="Edit your config",
)
@click.option("--path", "-p", help="Print the config location and exit", is_flag=True)
@@ -20,8 +20,14 @@ if TYPE_CHECKING:
help="Configure the desktop entry of fastanime",
is_flag=True,
)
@click.option(
"--update",
"-u",
help="Persist all the config options passed to fastanime to your config file",
is_flag=True,
)
@click.pass_obj
def config(config: "Config", path, view, desktop_entry):
def config(user_config: "Config", path, view, desktop_entry, update):
import sys
from rich import print
@@ -32,7 +38,7 @@ def config(config: "Config", path, view, desktop_entry):
if path:
print(USER_CONFIG_PATH)
elif view:
print(config)
print(user_config)
elif desktop_entry:
import os
import shutil
@@ -87,7 +93,9 @@ def config(config: "Config", path, view, desktop_entry):
with open(desktop_entry_path) as f:
print(f"Successfully wrote \n{f.read()}")
exit_app(0)
elif update:
with open(USER_CONFIG_PATH, "w") as file:
file.write(user_config.__repr__())
print("update successfull")
else:
import click
click.edit(filename=USER_CONFIG_PATH)

View File

@@ -4,8 +4,6 @@ import os
from configparser import ConfigParser
from typing import TYPE_CHECKING
from rich import print
from ..constants import USER_CONFIG_PATH, USER_DATA_PATH, USER_VIDEOS_DIR
from ..libs.rofi import Rofi
@@ -104,13 +102,11 @@ class Config(object):
self.configparser.add_section("stream")
self.configparser.add_section("general")
self.configparser.add_section("anilist")
if not os.path.exists(USER_CONFIG_PATH):
with open(USER_CONFIG_PATH, "w") as config:
self.configparser.write(config)
self.configparser.read(USER_CONFIG_PATH)
# --- set config values from file or using defaults ---
if os.path.exists(USER_CONFIG_PATH):
self.configparser.read(USER_CONFIG_PATH)
self.downloads_dir = self.get_downloads_dir()
self.sub_lang = self.get_sub_lang()
self.provider = self.get_provider()
@@ -125,7 +121,7 @@ class Config(object):
self.auto_next = self.get_auto_next()
self.normalize_titles = self.get_normalize_titles()
self.auto_select = self.get_auto_select()
self.use_mpv_mod = self.get_use_mpv_mod()
self.use_python_mpv = self.get_use_mpv_mod()
self.quality = self.get_quality()
self.notification_duration = self.get_notification_duration()
self.error = self.get_error()
@@ -147,6 +143,9 @@ class Config(object):
self.user: dict = self.user_data.get("user", {})
os.environ["CURRENT_FASTANIME_PROVIDER"] = self.provider
if not os.path.exists(USER_CONFIG_PATH):
with open(USER_CONFIG_PATH, "w") as config:
config.write(self.__repr__())
def update_user(self, user):
self.user = user
@@ -274,7 +273,15 @@ class Config(object):
self.configparser.write(config)
def __repr__(self):
current_config_state = f"""
current_config_state = f"""\
#
# ███████╗░█████╗░░██████╗████████╗░█████╗░███╗░░██╗██╗███╗░░░███╗███████╗ ░█████╗░░█████╗░███╗░░██╗███████╗██╗░██████╗░
# ██╔════╝██╔══██╗██╔════╝╚══██╔══╝██╔══██╗████╗░██║██║████╗░████║██╔════╝ ██╔══██╗██╔══██╗████╗░██║██╔════╝██║██╔════╝░
# █████╗░░███████║╚█████╗░░░░██║░░░███████║██╔██╗██║██║██╔████╔██║█████╗░░ ██║░░╚═╝██║░░██║██╔██╗██║█████╗░░██║██║░░██╗░
# ██╔══╝░░██╔══██║░╚═══██╗░░░██║░░░██╔══██║██║╚████║██║██║╚██╔╝██║██╔══╝░░ ██║░░██╗██║░░██║██║╚████║██╔══╝░░██║██║░░╚██╗
# ██║░░░░░██║░░██║██████╔╝░░░██║░░░██║░░██║██║░╚███║██║██║░╚═╝░██║███████╗ ╚█████╔╝╚█████╔╝██║░╚███║██║░░░░░██║╚██████╔╝
# ╚═╝░░░░░╚═╝░░╚═╝╚═════╝░░░░╚═╝░░░╚═╝░░╚═╝╚═╝░░╚══╝╚═╝╚═╝░░░░░╚═╝╚══════╝ ░╚════╝░░╚════╝░╚═╝░░╚══╝╚═╝░░░░░╚═╝░╚═════╝░
#
[stream]
# Auto continue from watch history
continue_from_history = {self.continue_from_history}
@@ -307,7 +314,7 @@ error = {self.error}
# whether to use python-mpv
# to enable superior control over the player
# adding more options to it
use_mpv_mod = {self.use_mpv_mod}
use_mpv_mod = {self.use_python_mpv}
# force mpv window
# passed directly to mpv so values are same
@@ -367,18 +374,3 @@ notification_duration = {self.notification_duration}
def __str__(self):
return self.__repr__()
# WARNING: depracated and will probably be removed
def update_anime_list(self, anime_id: int, remove=False):
if remove:
try:
self.anime_list.remove(anime_id)
print("Succesfully removed :cry:")
except Exception:
print(anime_id, "Nothing to remove :confused:")
else:
self.anime_list.append(anime_id)
self.user_data["animelist"] = list(set(self.anime_list))
self._update_user_data()
print("Succesfully added :smile:")
input("Enter to continue...")

View File

@@ -141,7 +141,7 @@ def media_player_controls(
headers=selected_server["headers"],
subtitles=subtitles,
)
elif config.use_mpv_mod:
elif config.use_python_mpv:
from ..utils.player import player
player.create_player(
@@ -545,7 +545,7 @@ def provider_anime_episode_servers_menu(
headers=selected_server["headers"],
subtitles=subtitles,
)
elif config.use_mpv_mod:
elif config.use_python_mpv:
from ..utils.player import player
if start_time == "0" and episode_in_history != current_episode_number:
@@ -1072,13 +1072,13 @@ def media_actions_menu(
# update internal config
if player == "syncplay":
config.sync_play = True
config.use_mpv_mod = False
config.use_python_mpv = False
else:
config.sync_play = False
if player == "mpv-mod":
config.use_mpv_mod = True
config.use_python_mpv = True
else:
config.use_mpv_mod = False
config.use_python_mpv = False
media_actions_menu(config, fastanime_runtime_state)
def _view_info(config: "Config", fastanime_runtime_state: "FastAnimeRuntimeState"):

View File

@@ -5,7 +5,6 @@ import subprocess
import sys
from typing import Callable, List
# TODO: will probably scrap art not to useful
from click import clear
from rich import print