music-kraken-core/src/music_kraken/__init__.py

90 lines
2.1 KiB
Python
Raw Normal View History

import gc
2023-03-31 08:34:29 +00:00
from pathlib import Path
from typing import List
2022-11-23 07:24:05 +00:00
import musicbrainzngs
import logging
2023-03-30 10:43:43 +00:00
import re
2022-11-23 07:24:05 +00:00
from . import (
2023-03-02 06:59:53 +00:00
objects,
2023-02-09 08:40:57 +00:00
pages
)
2023-02-06 08:16:28 +00:00
2022-11-23 07:24:05 +00:00
from .utils.shared import (
MUSIC_DIR,
NOT_A_GENRE
)
2022-11-24 13:56:51 +00:00
"""
At the start I modify the garbage collector to run a bit fewer times.
This should increase speed:
https://mkennedy.codes/posts/python-gc-settings-change-this-and-make-your-app-go-20pc-faster/
"""
# Clean up what might be garbage so far.
gc.collect(2)
allocs, gen1, gen2 = gc.get_threshold()
allocs = 50_000 # Start the GC sequence every 50K not 700 allocations.
gen1 = gen1 * 2
gen2 = gen2 * 2
gc.set_threshold(allocs, gen1, gen2)
2022-11-22 13:53:29 +00:00
logging.getLogger("musicbrainzngs").setLevel(logging.WARNING)
musicbrainzngs.set_useragent("metadata receiver", "0.1", "https://github.com/HeIIow2/music-downloader")
2023-03-30 10:43:43 +00:00
URL_REGGEX = 'https?://(?:[-\w.]|(?:%[\da-fA-F]{2}))+'
2023-03-31 08:34:29 +00:00
DOWNLOAD_COMMANDS = {
"ok",
"download",
"\d",
"hs"
}
2023-03-30 10:43:43 +00:00
2022-11-24 17:25:49 +00:00
2023-02-09 08:40:57 +00:00
def cli():
2023-03-30 08:49:17 +00:00
def next_search(search: pages.Search, query: str):
query: str = query.strip()
parsed: str = query.lower()
if parsed == ".":
return
if parsed == "..":
search.goto_previous()
return
if parsed.isdigit():
search.choose_index(int(parsed))
return
2023-03-31 08:34:29 +00:00
if parsed in DOWNLOAD_COMMANDS:
print(search.download_chosen())
2023-03-30 10:43:43 +00:00
url = re.match(URL_REGGEX, query)
if url is not None:
if not search.search_url(url.string):
print("The given url couldn't be downloaded")
return
page = search.get_page_from_query(parsed)
2023-03-30 08:49:17 +00:00
if page is not None:
search.choose_page(page)
return
# if everything else is not valid search
search.search(query)
2023-03-29 15:24:02 +00:00
2023-03-30 08:49:17 +00:00
search = pages.Search()
2023-03-29 15:24:02 +00:00
while True:
next_input = input(">> ")
if next_input in {
"exit",
"quit"
}:
print("byeeee UwU")
break
next_search(search, next_input)
2023-03-29 15:24:02 +00:00
print(search)
2023-03-30 08:49:17 +00:00