add file manager
This commit is contained in:
@@ -1,6 +1,9 @@
|
||||
import os
|
||||
import imghdr
|
||||
import argparse
|
||||
from pathlib import Path
|
||||
|
||||
from loguru import logger
|
||||
|
||||
|
||||
def parse_args():
|
||||
@@ -48,7 +51,12 @@ def parse_args():
|
||||
help="Set window size for GUI",
|
||||
)
|
||||
parser.add_argument(
|
||||
"--input", type=str, help="Path to image you want to load by default"
|
||||
"--input", type=str,
|
||||
help="If input is image, it will be load by default. If input is directory, all images will be loaded to file manager"
|
||||
)
|
||||
parser.add_argument(
|
||||
"--output-dir", type=str,
|
||||
help="Only required when --input is directory. Output directory for all processed images"
|
||||
)
|
||||
parser.add_argument("--disable-model-switch", action="store_true", help="Disable model switch in frontend")
|
||||
parser.add_argument("--debug", action="store_true")
|
||||
@@ -57,8 +65,20 @@ def parse_args():
|
||||
if args.input is not None:
|
||||
if not os.path.exists(args.input):
|
||||
parser.error(f"invalid --input: {args.input} not exists")
|
||||
if imghdr.what(args.input) is None:
|
||||
parser.error(f"invalid --input: {args.input} is not a valid image file")
|
||||
if os.path.isfile(args.input):
|
||||
if imghdr.what(args.input) is None:
|
||||
parser.error(f"invalid --input: {args.input} is not a valid image file")
|
||||
else:
|
||||
if args.output_dir is None:
|
||||
parser.error(f"invalid --input: {args.input} is a directory, --output-dir is required")
|
||||
else:
|
||||
output_dir = Path(args.output_dir)
|
||||
if not output_dir.exists():
|
||||
logger.info(f"Creating output directory: {output_dir}")
|
||||
output_dir.mkdir(parents=True)
|
||||
else:
|
||||
if not output_dir.is_dir():
|
||||
parser.error(f"invalid --output-dir: {output_dir} is not a directory")
|
||||
|
||||
if args.model == 'sd1.5' and not args.sd_run_local:
|
||||
if not args.hf_access_token.startswith("hf_"):
|
||||
|
||||
Reference in New Issue
Block a user