2018-03-29 00:07:35 +08:00
|
|
|
import subprocess
|
|
|
|
from subprocess import check_output
|
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
import sys
|
2017-12-30 13:09:51 +08:00
|
|
|
|
|
|
|
try:
|
2018-03-29 00:07:35 +08:00
|
|
|
logging.info('Installing Python modules required for Bazarr...')
|
2018-01-11 00:44:47 +08:00
|
|
|
|
2018-08-23 11:41:58 +08:00
|
|
|
command = sys.executable + ' -m pip --disable-pip-version-check -q -q install --user -r "' + os.path.join(os.path.dirname(__file__), 'requirements.txt"')
|
2018-01-23 12:25:58 +08:00
|
|
|
|
2018-03-29 00:07:35 +08:00
|
|
|
if os.name == 'nt':
|
|
|
|
codepage = check_output("chcp", shell=True, stderr=subprocess.STDOUT)
|
|
|
|
encoding = codepage.split(':')[-1].strip()
|
2018-03-10 12:17:51 +08:00
|
|
|
|
2018-03-29 00:07:35 +08:00
|
|
|
process = check_output(command, shell=True, stderr=subprocess.STDOUT)
|
|
|
|
|
|
|
|
if os.name == 'nt':
|
|
|
|
process = process.decode(encoding)
|
2018-07-02 10:20:14 +08:00
|
|
|
except Exception as e:
|
|
|
|
logging.exception('Unable to install requirements using command line PIP.')
|
2018-03-29 00:07:35 +08:00
|
|
|
pass
|
|
|
|
else:
|
|
|
|
if process == "":
|
|
|
|
logging.info('Required Python modules installed if missing.')
|
|
|
|
else:
|
|
|
|
for line in process.splitlines():
|
|
|
|
logging.error(line)
|