much progress in cleaning up
This commit is contained in:
@@ -1,29 +1,49 @@
|
||||
from typing import Tuple, Type, Dict, List
|
||||
import threading
|
||||
from queue import Queue
|
||||
from typing import Tuple, Type, Dict, List, Set
|
||||
|
||||
from ..utils.enums.source import SourcePages
|
||||
from ..utils.support_classes import Query, EndThread
|
||||
from ..pages import Page, EncyclopaediaMetallum, Musify
|
||||
|
||||
ALL_PAGES: Tuple[Type[Page], ...] = (
|
||||
ALL_PAGES: Set[Type[Page]] = {
|
||||
EncyclopaediaMetallum,
|
||||
Musify
|
||||
)
|
||||
}
|
||||
|
||||
AUDIO_PAGES: Tuple[Type[Page], ...] = (
|
||||
AUDIO_PAGES: Set[Type[Page]] = {
|
||||
Musify,
|
||||
)
|
||||
}
|
||||
|
||||
SHADY_PAGES: Tuple[Type[Page], ...] = (
|
||||
SHADY_PAGES: Set[Type[Page]] = {
|
||||
Musify,
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
exit_threads = EndThread()
|
||||
search_queue: Queue[Query] = Queue()
|
||||
|
||||
_page_threads: Dict[Type[Page], List[Page]] = dict()
|
||||
class Pages:
|
||||
def __init__(self, exclude_pages: Set[Type[Page]] = None, exclude_shady: bool = False) -> None:
|
||||
# initialize all page instances
|
||||
self._page_instances: Dict[Type[Page], Page] = dict()
|
||||
|
||||
exclude_pages = exclude_pages if exclude_pages is not None else set()
|
||||
|
||||
if exclude_shady:
|
||||
exclude_pages = exclude_pages.union(SHADY_PAGES)
|
||||
|
||||
if not exclude_pages.issubset(ALL_PAGES):
|
||||
raise ValueError(f"The excluded pages have to be a subset of all pages: {exclude_pages} | {ALL_PAGES}")
|
||||
|
||||
def _set_to_tuple(page_set: Set[Type[Page]]) -> Tuple[Type[Page], ...]:
|
||||
return tuple(sorted(page_set, key=lambda page: page.__name__))
|
||||
|
||||
self.pages: Tuple[Type[Page], ...] = _set_to_tuple(ALL_PAGES.difference(exclude_pages))
|
||||
self.audio_pages: Tuple[Type[Page], ...] = _set_to_tuple(set(self.pages).intersection(AUDIO_PAGES))
|
||||
|
||||
for page_type in ALL_PAGES:
|
||||
self._page_instances[page_type] = page_type()
|
||||
|
||||
def search(self, query: Query):
|
||||
for page_type in self.pages:
|
||||
self._page_instances[page_type].search(query=query)
|
||||
|
||||
|
||||
"""
|
||||
|
||||
25
src/music_kraken/download/results.py
Normal file
25
src/music_kraken/download/results.py
Normal file
@@ -0,0 +1,25 @@
|
||||
from typing import Tuple, Type, Dict, List
|
||||
|
||||
from ..objects import DatabaseObject
|
||||
from ..utils.enums.source import SourcePages
|
||||
from ..pages import Page, EncyclopaediaMetallum, Musify
|
||||
|
||||
class SearchResults:
|
||||
def __init__(
|
||||
self,
|
||||
pages: Tuple[Type[Page], ...]
|
||||
|
||||
) -> None:
|
||||
self.pages = pages
|
||||
# this would initialize a list for every page, which I don't think I want
|
||||
# self.results = Dict[Type[Page], List[DatabaseObject]] = {page: [] for page in self.pages}
|
||||
self.results = Dict[Type[Page], List[DatabaseObject]] = {}
|
||||
|
||||
def add(self, page: Type[Page], search_result: List[DatabaseObject]):
|
||||
self.results[page] = search_result
|
||||
|
||||
def __str__(self) -> str:
|
||||
for page in self.pages:
|
||||
if page not in self.results:
|
||||
continue
|
||||
|
||||
Reference in New Issue
Block a user