mirror of
https://github.com/LSPosed/MagiskOnWSALocal.git
synced 2025-05-06 14:56:36 +08:00
Show more info when extracting WSA
This commit is contained in:
parent
d0e92b2395
commit
e7b1e89ada
@ -31,15 +31,17 @@ arch = sys.argv[1]
|
|||||||
zip_name = ""
|
zip_name = ""
|
||||||
wsa_zip_path_raw = sys.argv[2]
|
wsa_zip_path_raw = sys.argv[2]
|
||||||
|
|
||||||
wsa_zip_path= Path(wsa_zip_path_raw).resolve()
|
wsa_zip_path = Path(wsa_zip_path_raw).resolve()
|
||||||
rootdir = Path(sys.argv[3]).resolve()
|
rootdir = Path(sys.argv[3]).resolve()
|
||||||
env_file_raw = sys.argv[4]
|
env_file_raw = sys.argv[4]
|
||||||
print(f"wsa_zip_path_raw: {wsa_zip_path_raw}, env_file_raw: {env_file_raw}", flush=True)
|
print(
|
||||||
|
f"wsa_zip_path_raw: {wsa_zip_path_raw}, env_file_raw: {env_file_raw}", flush=True)
|
||||||
env_file = Path(env_file_raw).resolve()
|
env_file = Path(env_file_raw).resolve()
|
||||||
|
|
||||||
workdir = rootdir / "wsa"
|
workdir = rootdir / "wsa"
|
||||||
archdir = Path(workdir / arch)
|
archdir = Path(workdir / arch)
|
||||||
|
pridir = workdir / archdir / 'pri'
|
||||||
|
xmldir = workdir / archdir / 'xml'
|
||||||
if not Path(rootdir).is_dir():
|
if not Path(rootdir).is_dir():
|
||||||
rootdir.mkdir()
|
rootdir.mkdir()
|
||||||
|
|
||||||
@ -53,19 +55,16 @@ if not Path(workdir).is_dir():
|
|||||||
|
|
||||||
if not Path(archdir).is_dir():
|
if not Path(archdir).is_dir():
|
||||||
archdir.mkdir()
|
archdir.mkdir()
|
||||||
print(f"extracting {arch} from {wsa_zip_path} to {archdir}", flush=True)
|
uid = os.getuid()
|
||||||
|
workdir_rw = os.access(workdir, os.W_OK)
|
||||||
|
print(f"Uid {uid} can write to {workdir} {workdir_rw}", flush=True)
|
||||||
with zipfile.ZipFile(wsa_zip_path) as zip:
|
with zipfile.ZipFile(wsa_zip_path) as zip:
|
||||||
for f in zip.filelist:
|
for f in zip.filelist:
|
||||||
if arch in f.filename.lower():
|
if arch in f.filename.lower():
|
||||||
zip_name = f.filename
|
zip_name = f.filename
|
||||||
if not Path(workdir / zip_name).is_file():
|
if not Path(workdir / zip_name).is_file():
|
||||||
zip_path = workdir / zip_name
|
|
||||||
print(f"unzipping {zip_name} to {workdir}", flush=True)
|
print(f"unzipping {zip_name} to {workdir}", flush=True)
|
||||||
uid = os.getuid()
|
zip_path = zip.extract(f, workdir)
|
||||||
workdir_rw = os.access(workdir, os.W_OK)
|
|
||||||
print(f"Uid {uid} can write to \"{workdir}\"? : {workdir_rw}", flush=True)
|
|
||||||
extract_ret = zip.extract(f, workdir)
|
|
||||||
print(f"extract_ret: {extract_ret}", flush=True)
|
|
||||||
ver_no = zip_name.split("_")
|
ver_no = zip_name.split("_")
|
||||||
long_ver = ver_no[1]
|
long_ver = ver_no[1]
|
||||||
ver = long_ver.split(".")
|
ver = long_ver.split(".")
|
||||||
@ -76,18 +75,23 @@ with zipfile.ZipFile(wsa_zip_path) as zip:
|
|||||||
environ_file.write(f'WSA_VER={long_ver}\n')
|
environ_file.write(f'WSA_VER={long_ver}\n')
|
||||||
environ_file.write(f'WSA_MAIN_VER={main_ver}\n')
|
environ_file.write(f'WSA_MAIN_VER={main_ver}\n')
|
||||||
environ_file.write(f'WSA_REL={rel_long}\n')
|
environ_file.write(f'WSA_REL={rel_long}\n')
|
||||||
if 'language' in f.filename.lower() or 'scale' in f.filename.lower():
|
filename_lower = f.filename.lower()
|
||||||
|
if 'language' in filename_lower or 'scale' in filename_lower:
|
||||||
|
print(f"unzipping {filename_lower}", flush=True)
|
||||||
name = f.filename.split("_")[2].split(".")[0]
|
name = f.filename.split("_")[2].split(".")[0]
|
||||||
zip.extract(f, workdir)
|
zip.extract(f, workdir)
|
||||||
with zipfile.ZipFile(workdir / f.filename) as l:
|
with zipfile.ZipFile(workdir / f.filename) as l:
|
||||||
for g in l.filelist:
|
for g in l.filelist:
|
||||||
if g.filename == 'resources.pri':
|
if g.filename == 'resources.pri':
|
||||||
g.filename = f'resources.{name}.pri'
|
g.filename = f'resources.{name}.pri'
|
||||||
l.extract(g, workdir / archdir / 'pri')
|
print(f"extracting {g.filename}", flush=True)
|
||||||
|
l.extract(g, pridir)
|
||||||
elif g.filename == 'AppxManifest.xml':
|
elif g.filename == 'AppxManifest.xml':
|
||||||
g.filename = f'resources.{name}.xml'
|
g.filename = f'resources.{name}.xml'
|
||||||
l.extract(g, workdir / archdir / 'xml')
|
print(f"extracting {g.filename}", flush=True)
|
||||||
|
l.extract(g, xmldir)
|
||||||
elif re.search(u'Images/.+\.png', g.filename):
|
elif re.search(u'Images/.+\.png', g.filename):
|
||||||
|
print(f"extracting {g.filename}", flush=True)
|
||||||
l.extract(g, archdir)
|
l.extract(g, archdir)
|
||||||
with zipfile.ZipFile(zip_path) as zip:
|
with zipfile.ZipFile(zip_path) as zip:
|
||||||
print(f"unzipping from {zip_path}", flush=True)
|
print(f"unzipping from {zip_path}", flush=True)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user