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
|
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
import sys
from mozboot.base import MERCURIAL_INSTALL_PROMPT, BaseBootstrapper
from mozboot.linux_common import LinuxBootstrapper
class DebianBootstrapper(LinuxBootstrapper, BaseBootstrapper):
def __init__(self, distro, version, dist_id, codename, **kwargs):
BaseBootstrapper.__init__(self, **kwargs)
self.distro = distro
self.version = version
self.dist_id = dist_id
self.codename = codename
def suggest_install_pip3(self):
print(
"HINT: Try installing pip3 with `apt-get install python3-pip`.",
file=sys.stderr,
)
def install_packages(self, packages):
try:
if int(self.version) < 11:
# watchman is only available starting from Debian 11.
packages = [p for p in packages if p != "watchman"]
except ValueError:
pass
self.apt_install(*packages)
def _update_package_manager(self):
self.apt_update()
def upgrade_mercurial(self, current):
"""Install Mercurial from pip because Debian packages typically lag."""
if self.no_interactive:
# Install via Apt in non-interactive mode because it is the more
# conservative option and less likely to make people upset.
self.apt_install("mercurial")
return
res = self.prompt_int(MERCURIAL_INSTALL_PROMPT, 1, 3)
# Apt.
if res == 2:
self.apt_install("mercurial")
return False
# No Mercurial.
if res == 3:
print("Not installing Mercurial.")
return False
# pip.
assert res == 1
self.run_as_root(["pip3", "install", "--upgrade", "Mercurial"])
def apt_install(self, *packages):
command = ["apt-get", "install"]
if self.no_interactive:
command.append("-y")
command.extend(packages)
self.run_as_root(command)
def apt_update(self):
command = ["apt-get", "update"]
if self.no_interactive:
command.append("-y")
self.run_as_root(command)
|