mirror of
https://github.com/Radiquum/furaffinity-dl.git
synced 2025-04-05 15:54:38 +00:00
feat: add disable of threading and configure the number of running threads
fix: NoneType error if no arguments are provided
This commit is contained in:
parent
d8a6fffa0b
commit
c0962094ca
2 changed files with 60 additions and 35 deletions
|
@ -163,6 +163,20 @@ parser.add_argument(
|
||||||
action="store_true",
|
action="store_true",
|
||||||
help="check all files size when download, this will skip build-in archive",
|
help="check all files size when download, this will skip build-in archive",
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--disable-threading",
|
||||||
|
dest="disable_threading",
|
||||||
|
action="store_true",
|
||||||
|
help="disable multithreading download",
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--num-threads",
|
||||||
|
"-t",
|
||||||
|
dest="num_threads",
|
||||||
|
default=3,
|
||||||
|
help="how many threads will be used for parallel download [default: 3]",
|
||||||
|
type=int,
|
||||||
|
)
|
||||||
|
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
@ -181,30 +195,32 @@ if username is not None:
|
||||||
username = username[0]
|
username = username[0]
|
||||||
|
|
||||||
# Custom input
|
# Custom input
|
||||||
cookies = args.cookies
|
cookies: str = args.cookies
|
||||||
output_folder = args.output_folder
|
output_folder: str = args.output_folder
|
||||||
download = args.download
|
download: int = args.download
|
||||||
interval = args.interval
|
interval: int = args.interval
|
||||||
user_agent = args.user_agent
|
user_agent: str = args.user_agent
|
||||||
start = args.start
|
start: int = args.start
|
||||||
stop = args.stop
|
stop: int = args.stop
|
||||||
folder = args.folder
|
folder: str = args.folder
|
||||||
|
num_threads: int = args.num_threads
|
||||||
|
|
||||||
# True\False
|
# True\False
|
||||||
|
|
||||||
login = args.login
|
login: bool = args.login
|
||||||
check = args.check
|
check: bool = args.check
|
||||||
index = args.index
|
index: bool = args.index
|
||||||
submissions = args.submissions
|
submissions: bool = args.submissions
|
||||||
html_description = args.html_description
|
html_description: bool = args.html_description
|
||||||
json_description = args.json_description
|
json_description: bool = args.json_description
|
||||||
metadata = args.metadata
|
metadata: bool = args.metadata
|
||||||
dont_redownload = args.redownload
|
dont_redownload: bool = args.redownload
|
||||||
rating = args.rating
|
rating: bool = args.rating
|
||||||
submission_filter = args.submission_filter
|
submission_filter: bool = args.submission_filter
|
||||||
real_category = args.real_category
|
real_category: bool = args.real_category
|
||||||
request_compress = args.request_compress
|
request_compress: bool = args.request_compress
|
||||||
check_file_size = args.check_file_size
|
check_file_size: bool = args.check_file_size
|
||||||
|
disable_threading: bool = args.disable_threading
|
||||||
|
|
||||||
if check_file_size:
|
if check_file_size:
|
||||||
request_compress = False
|
request_compress = False
|
||||||
|
|
|
@ -82,13 +82,16 @@ it\'s already downloaded{config.END}'
|
||||||
)
|
)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
#download(img_url)
|
if config.disable_threading:
|
||||||
|
download(img_url)
|
||||||
|
else:
|
||||||
q.put(img_url)
|
q.put(img_url)
|
||||||
sleep(config.interval)
|
sleep(config.interval)
|
||||||
q.join()
|
q.join()
|
||||||
page_num = next_button(page_url)
|
page_num = next_button(page_url)
|
||||||
|
if not config.disable_threading:
|
||||||
stop_threads = True
|
stop_threads = True
|
||||||
for _ in range(3):
|
for _ in range(config.num_threads):
|
||||||
q.put("shutdown")
|
q.put("shutdown")
|
||||||
for t in workers:
|
for t in workers:
|
||||||
t.join()
|
t.join()
|
||||||
|
@ -126,8 +129,9 @@ is inaccessible{config.END}"
|
||||||
download(f"/view/{config.download}/")
|
download(f"/view/{config.download}/")
|
||||||
exit()
|
exit()
|
||||||
|
|
||||||
|
if not config.disable_threading:
|
||||||
stop_threads = False
|
stop_threads = False
|
||||||
for id in range(3):
|
for id in range(config.num_threads):
|
||||||
print(id, 'started thread')
|
print(id, 'started thread')
|
||||||
tmp = threading.Thread(target=worker, daemon=False)
|
tmp = threading.Thread(target=worker, daemon=False)
|
||||||
workers.append(tmp)
|
workers.append(tmp)
|
||||||
|
@ -160,6 +164,11 @@ downloading "{config.folder[1]}"{config.END}'
|
||||||
)
|
)
|
||||||
exit()
|
exit()
|
||||||
|
|
||||||
|
if not config.username:
|
||||||
|
print("Not enough arguments")
|
||||||
|
config.parser.print_help()
|
||||||
|
os._exit(1)
|
||||||
|
|
||||||
for username in config.username:
|
for username in config.username:
|
||||||
username = username.split("#")[0].translate(
|
username = username.split("#")[0].translate(
|
||||||
str.maketrans(config.username_replace_chars)
|
str.maketrans(config.username_replace_chars)
|
||||||
|
|
Loading…
Add table
Reference in a new issue