Merge branch 'fix-import-python-3-5' into 'develop'

Fix support for Python 3.5 in import script

Closes #1147 and #1148

See merge request funkwhale/funkwhale!1129
This commit is contained in:
Agate 2020-06-05 05:38:06 +02:00
commit 6b0e022286
2 changed files with 21 additions and 11 deletions

View File

@ -23,21 +23,30 @@ from funkwhale_api.common import utils as common_utils
from funkwhale_api.music import models, tasks, utils
def dir_scanner(scanner, extensions, recursive, ignored):
for entry in scanner:
if entry.is_file():
for e in extensions:
if entry.name.lower().endswith(".{}".format(e.lower())):
if entry.path not in ignored:
yield entry.path
elif recursive and entry.is_dir():
yield from dir_scanner(
entry, extensions, recursive=recursive, ignored=ignored
)
def crawl_dir(dir, extensions, recursive=True, ignored=[]):
if os.path.isfile(dir):
yield dir
return
with os.scandir(dir) as scanner:
for entry in scanner:
if entry.is_file():
for e in extensions:
if entry.name.lower().endswith(".{}".format(e.lower())):
if entry.path not in ignored:
yield entry.path
elif recursive and entry.is_dir():
yield from crawl_dir(
entry, extensions, recursive=recursive, ignored=ignored
)
else:
try:
scanner = os.scandir(dir)
yield from dir_scanner(scanner, extensions, recursive, ignored)
finally:
if hasattr(scanner, "close"):
scanner.close()
def batch(iterable, n=1):

View File

@ -0,0 +1 @@
Fixed an issue where in-place importing didn't work for directories on machines running Python 3.5 (#1148, #1147)