forked from 07th-mod/python-patcher
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuminekoNScripterInstaller.py
84 lines (65 loc) · 3.37 KB
/
uminekoNScripterInstaller.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
from __future__ import unicode_literals
import commandLineParser
import common
import os
import fileVersionManagement
import gameScanner
import installConfiguration
import logger
#do install given a installer config object
def main(conf):
# type: (installConfiguration.FullInstallConfiguration) -> None
logger.getGlobalLogger().trySetSecondaryLoggingPath(
os.path.join(conf.installPath, common.Globals.LOG_BASENAME)
)
print("CONFIGURATION:")
print("Install path", conf.installPath)
print("Mod Option", conf.subModConfig.modName)
print("Sub Option", conf.subModConfig.subModName)
print("Is Windows", common.Globals.IS_WINDOWS)
print("Is Linux", common.Globals.IS_LINUX)
print("Is Mac", common.Globals.IS_MAC)
if not common.Globals.IS_WINDOWS:
raise Exception("Error: Umineko Hane Mod (onscripter version) is not supported on Mac or Linux!")
####################################### VALIDATE AND PREPARE FOLDERS ###############################################
# do a quick verification that the directory is correct before starting installer
if not os.path.isfile(os.path.join(conf.installPath, "arc.nsa")):
raise Exception("ERROR - wrong game path. Installation Stopped.\n"
"There is no 'arc.nsa' in the game folder. Are you sure the correct game folder was selected?")
# Create aliases for the temp directories, and ensure they exist beforehand
downloadTempDir = conf.subModConfig.modName + " Downloads"
if os.path.isdir(downloadTempDir):
print("Information: Temp directories already exist - continued or overwritten install")
common.makeDirsExistOK(downloadTempDir)
######################################## DOWNLOAD, BACKUP, THEN EXTRACT ############################################
fileVersionManager = fileVersionManagement.VersionManager(
fullInstallConfiguration=conf,
modFileList=conf.buildFileListSorted(),
localVersionFolder=conf.installPath)
parser = installConfiguration.ModOptionParser(conf)
skipDownload = parser.downloadManually
filesRequiringUpdate = fileVersionManager.getFilesRequiringUpdate()
conf.subModConfig.printEnabledOptions()
downloaderAndExtractor = common.DownloaderAndExtractor(filesRequiringUpdate, downloadTempDir, conf.installPath, downloadProgressAmount=45, extractionProgressAmount=45, skipDownload=skipDownload)
downloaderAndExtractor.buildDownloadAndExtractionList()
for opt in parser.downloadAndExtractOptionsByPriority:
downloaderAndExtractor.addItemManually(
url=opt.url,
extractionDir=os.path.join(conf.installPath, opt.relativeExtractionPath),
)
downloaderAndExtractor.printPreview()
# Download files
# Delete all non-checksummed files from the download folder, if they exist
for extractableItem in downloaderAndExtractor.extractList:
extractableItemPath = os.path.join(downloadTempDir, extractableItem.filename)
if not extractableItem.fromMetaLink and os.path.exists(extractableItemPath):
print("Removing existing non-checksummed download: [{}]".format(extractableItemPath))
os.remove(extractableItemPath)
downloaderAndExtractor.download()
# If any mod options request deletion of a folder, do it before the extraction
common.applyDeletions(conf.installPath, parser)
# Extract files
fileVersionManager.saveVersionInstallStarted()
downloaderAndExtractor.extract()
fileVersionManager.saveVersionInstallFinished()
commandLineParser.printSeventhModStatusUpdate(100, "Umineko Hane install script completed!")