jolt 0.9.123__py3-none-any.whl → 0.9.435__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (196) hide show
  1. jolt/__init__.py +80 -7
  2. jolt/__main__.py +9 -1
  3. jolt/bin/fstree-darwin-x86_64 +0 -0
  4. jolt/bin/fstree-linux-x86_64 +0 -0
  5. jolt/cache.py +832 -362
  6. jolt/chroot.py +156 -0
  7. jolt/cli.py +281 -162
  8. jolt/common_pb2.py +63 -0
  9. jolt/common_pb2_grpc.py +4 -0
  10. jolt/config.py +98 -41
  11. jolt/error.py +19 -4
  12. jolt/filesystem.py +2 -6
  13. jolt/graph.py +705 -117
  14. jolt/hooks.py +43 -0
  15. jolt/influence.py +122 -3
  16. jolt/loader.py +369 -121
  17. jolt/log.py +225 -63
  18. jolt/manifest.py +28 -38
  19. jolt/options.py +35 -10
  20. jolt/pkgs/abseil.py +42 -0
  21. jolt/pkgs/asio.py +25 -0
  22. jolt/pkgs/autoconf.py +41 -0
  23. jolt/pkgs/automake.py +41 -0
  24. jolt/pkgs/b2.py +31 -0
  25. jolt/pkgs/boost.py +111 -0
  26. jolt/pkgs/boringssl.py +32 -0
  27. jolt/pkgs/busybox.py +39 -0
  28. jolt/pkgs/bzip2.py +43 -0
  29. jolt/pkgs/cares.py +29 -0
  30. jolt/pkgs/catch2.py +36 -0
  31. jolt/pkgs/cbindgen.py +17 -0
  32. jolt/pkgs/cista.py +19 -0
  33. jolt/pkgs/clang.py +44 -0
  34. jolt/pkgs/cli11.py +24 -0
  35. jolt/pkgs/cmake.py +48 -0
  36. jolt/pkgs/cpython.py +196 -0
  37. jolt/pkgs/crun.py +29 -0
  38. jolt/pkgs/curl.py +38 -0
  39. jolt/pkgs/dbus.py +18 -0
  40. jolt/pkgs/double_conversion.py +24 -0
  41. jolt/pkgs/fastfloat.py +21 -0
  42. jolt/pkgs/ffmpeg.py +28 -0
  43. jolt/pkgs/flatbuffers.py +29 -0
  44. jolt/pkgs/fmt.py +27 -0
  45. jolt/pkgs/fstree.py +20 -0
  46. jolt/pkgs/gflags.py +18 -0
  47. jolt/pkgs/glib.py +18 -0
  48. jolt/pkgs/glog.py +25 -0
  49. jolt/pkgs/glslang.py +21 -0
  50. jolt/pkgs/golang.py +16 -11
  51. jolt/pkgs/googlebenchmark.py +18 -0
  52. jolt/pkgs/googletest.py +46 -0
  53. jolt/pkgs/gperf.py +15 -0
  54. jolt/pkgs/grpc.py +73 -0
  55. jolt/pkgs/hdf5.py +19 -0
  56. jolt/pkgs/help2man.py +14 -0
  57. jolt/pkgs/inja.py +28 -0
  58. jolt/pkgs/jsoncpp.py +31 -0
  59. jolt/pkgs/libarchive.py +43 -0
  60. jolt/pkgs/libcap.py +44 -0
  61. jolt/pkgs/libdrm.py +44 -0
  62. jolt/pkgs/libedit.py +42 -0
  63. jolt/pkgs/libevent.py +31 -0
  64. jolt/pkgs/libexpat.py +27 -0
  65. jolt/pkgs/libfastjson.py +21 -0
  66. jolt/pkgs/libffi.py +16 -0
  67. jolt/pkgs/libglvnd.py +30 -0
  68. jolt/pkgs/libogg.py +28 -0
  69. jolt/pkgs/libpciaccess.py +18 -0
  70. jolt/pkgs/libseccomp.py +21 -0
  71. jolt/pkgs/libtirpc.py +24 -0
  72. jolt/pkgs/libtool.py +42 -0
  73. jolt/pkgs/libunwind.py +35 -0
  74. jolt/pkgs/libva.py +18 -0
  75. jolt/pkgs/libvorbis.py +33 -0
  76. jolt/pkgs/libxml2.py +35 -0
  77. jolt/pkgs/libxslt.py +17 -0
  78. jolt/pkgs/libyajl.py +16 -0
  79. jolt/pkgs/llvm.py +81 -0
  80. jolt/pkgs/lua.py +54 -0
  81. jolt/pkgs/lz4.py +26 -0
  82. jolt/pkgs/m4.py +14 -0
  83. jolt/pkgs/make.py +17 -0
  84. jolt/pkgs/mesa.py +81 -0
  85. jolt/pkgs/meson.py +17 -0
  86. jolt/pkgs/mstch.py +28 -0
  87. jolt/pkgs/mysql.py +60 -0
  88. jolt/pkgs/nasm.py +49 -0
  89. jolt/pkgs/ncurses.py +30 -0
  90. jolt/pkgs/ng_log.py +25 -0
  91. jolt/pkgs/ninja.py +45 -0
  92. jolt/pkgs/nlohmann_json.py +25 -0
  93. jolt/pkgs/nodejs.py +19 -11
  94. jolt/pkgs/opencv.py +24 -0
  95. jolt/pkgs/openjdk.py +26 -0
  96. jolt/pkgs/openssl.py +103 -0
  97. jolt/pkgs/paho.py +76 -0
  98. jolt/pkgs/patchelf.py +16 -0
  99. jolt/pkgs/perl.py +42 -0
  100. jolt/pkgs/pkgconfig.py +64 -0
  101. jolt/pkgs/poco.py +39 -0
  102. jolt/pkgs/protobuf.py +77 -0
  103. jolt/pkgs/pugixml.py +27 -0
  104. jolt/pkgs/python.py +19 -0
  105. jolt/pkgs/qt.py +35 -0
  106. jolt/pkgs/rapidjson.py +26 -0
  107. jolt/pkgs/rapidyaml.py +28 -0
  108. jolt/pkgs/re2.py +30 -0
  109. jolt/pkgs/re2c.py +17 -0
  110. jolt/pkgs/readline.py +15 -0
  111. jolt/pkgs/rust.py +41 -0
  112. jolt/pkgs/sdl.py +28 -0
  113. jolt/pkgs/simdjson.py +27 -0
  114. jolt/pkgs/soci.py +46 -0
  115. jolt/pkgs/spdlog.py +29 -0
  116. jolt/pkgs/spirv_llvm.py +21 -0
  117. jolt/pkgs/spirv_tools.py +24 -0
  118. jolt/pkgs/sqlite.py +83 -0
  119. jolt/pkgs/ssl.py +12 -0
  120. jolt/pkgs/texinfo.py +15 -0
  121. jolt/pkgs/tomlplusplus.py +22 -0
  122. jolt/pkgs/wayland.py +26 -0
  123. jolt/pkgs/x11.py +58 -0
  124. jolt/pkgs/xerces_c.py +20 -0
  125. jolt/pkgs/xorg.py +360 -0
  126. jolt/pkgs/xz.py +29 -0
  127. jolt/pkgs/yamlcpp.py +30 -0
  128. jolt/pkgs/zeromq.py +47 -0
  129. jolt/pkgs/zlib.py +87 -0
  130. jolt/pkgs/zstd.py +33 -0
  131. jolt/plugins/alias.py +3 -0
  132. jolt/plugins/allure.py +5 -2
  133. jolt/plugins/autotools.py +66 -0
  134. jolt/plugins/cache.py +133 -0
  135. jolt/plugins/cmake.py +74 -6
  136. jolt/plugins/conan.py +238 -0
  137. jolt/plugins/cxx.py +698 -0
  138. jolt/plugins/cxxinfo.py +7 -0
  139. jolt/plugins/dashboard.py +1 -1
  140. jolt/plugins/docker.py +80 -23
  141. jolt/plugins/email.py +2 -2
  142. jolt/plugins/email.xslt +144 -101
  143. jolt/plugins/environ.py +11 -0
  144. jolt/plugins/fetch.py +141 -0
  145. jolt/plugins/gdb.py +39 -19
  146. jolt/plugins/gerrit.py +1 -14
  147. jolt/plugins/git.py +283 -85
  148. jolt/plugins/googletest.py +2 -1
  149. jolt/plugins/http.py +36 -38
  150. jolt/plugins/libtool.py +63 -0
  151. jolt/plugins/linux.py +990 -0
  152. jolt/plugins/logstash.py +4 -4
  153. jolt/plugins/meson.py +61 -0
  154. jolt/plugins/ninja-compdb.py +99 -30
  155. jolt/plugins/ninja.py +468 -166
  156. jolt/plugins/paths.py +11 -1
  157. jolt/plugins/pkgconfig.py +219 -0
  158. jolt/plugins/podman.py +136 -92
  159. jolt/plugins/python.py +137 -0
  160. jolt/plugins/remote_execution/__init__.py +0 -0
  161. jolt/plugins/remote_execution/administration_pb2.py +46 -0
  162. jolt/plugins/remote_execution/administration_pb2_grpc.py +170 -0
  163. jolt/plugins/remote_execution/log_pb2.py +32 -0
  164. jolt/plugins/remote_execution/log_pb2_grpc.py +68 -0
  165. jolt/plugins/remote_execution/scheduler_pb2.py +41 -0
  166. jolt/plugins/remote_execution/scheduler_pb2_grpc.py +141 -0
  167. jolt/plugins/remote_execution/worker_pb2.py +38 -0
  168. jolt/plugins/remote_execution/worker_pb2_grpc.py +112 -0
  169. jolt/plugins/report.py +12 -2
  170. jolt/plugins/rust.py +25 -0
  171. jolt/plugins/scheduler.py +710 -0
  172. jolt/plugins/selfdeploy/setup.py +8 -4
  173. jolt/plugins/selfdeploy.py +138 -88
  174. jolt/plugins/strings.py +35 -22
  175. jolt/plugins/symlinks.py +26 -11
  176. jolt/plugins/telemetry.py +5 -2
  177. jolt/plugins/timeline.py +13 -3
  178. jolt/plugins/volume.py +46 -48
  179. jolt/scheduler.py +589 -192
  180. jolt/tasks.py +625 -121
  181. jolt/templates/timeline.html.template +44 -47
  182. jolt/timer.py +22 -0
  183. jolt/tools.py +638 -282
  184. jolt/utils.py +211 -7
  185. jolt/version.py +1 -1
  186. jolt/xmldom.py +12 -2
  187. {jolt-0.9.123.dist-info → jolt-0.9.435.dist-info}/METADATA +97 -38
  188. jolt-0.9.435.dist-info/RECORD +207 -0
  189. {jolt-0.9.123.dist-info → jolt-0.9.435.dist-info}/WHEEL +1 -1
  190. jolt/plugins/amqp.py +0 -834
  191. jolt/plugins/debian.py +0 -338
  192. jolt/plugins/ftp.py +0 -181
  193. jolt/plugins/repo.py +0 -253
  194. jolt-0.9.123.dist-info/RECORD +0 -77
  195. {jolt-0.9.123.dist-info → jolt-0.9.435.dist-info}/entry_points.txt +0 -0
  196. {jolt-0.9.123.dist-info → jolt-0.9.435.dist-info}/top_level.txt +0 -0
jolt/plugins/fetch.py ADDED
@@ -0,0 +1,141 @@
1
+ import hashlib
2
+ from jolt import BooleanParameter, Parameter
3
+ from jolt.plugins.git import ErrorDict
4
+ from jolt.tasks import Resource, TaskRegistry
5
+ from jolt import filesystem as fs
6
+ from jolt import utils
7
+ from jolt.error import raise_error_if
8
+ from jolt.loader import JoltLoader
9
+ from jolt.tools import SUPPORTED_ARCHIVE_TYPES
10
+
11
+
12
+ class Fetch(Resource):
13
+ """
14
+ Fetch a file from a URL and extract it.
15
+
16
+ By default, the fetched file is extracted if it is a supported archive type.
17
+ Extraction may be disable by assigning the `extract` parameter to false.
18
+
19
+ The fetched content is placed in a build directory named after the resource.
20
+ The `path` parameter can be used to specify a different location relative to
21
+ the workspace root.
22
+
23
+ The path of the fetched content is made available to consuming tasks through
24
+ the `fetch` attribute. The `fetch` attribute is a dictionary where the key
25
+ is the name of the fetched file and the value is a path relative to the
26
+ workspace root. You can specify an alias for the filename / key through the
27
+ `alias` parameter.
28
+
29
+ The plugin must be loaded before it can be used. This is done by importing
30
+ the module, or by adding the following line to the configuration file:
31
+
32
+ .. code-block:: ini
33
+
34
+ [fetch]
35
+
36
+
37
+ Example:
38
+
39
+ .. code-block:: python
40
+
41
+ from jolt.plugins import fetch
42
+
43
+ class Example(Task):
44
+ requires = ["fetch:alias=zlib,url=https://zlib.net/zlib-1.3.1.tar.gz"]
45
+
46
+ def run(self, deps, tools):
47
+ self.info("The source tree is located at: {fetch[zlib]}")
48
+ with tools.cwd(self.fetch["zlib"]):
49
+ tools.run("make")
50
+
51
+ """
52
+
53
+ name = "fetch"
54
+ alias = Parameter(required=False, help="Name of the task used when referencing content. Defaults to the filename of the fetched file.")
55
+ extract = BooleanParameter(default=True, help="Whether to extract the fetched file.")
56
+ path = Parameter(required=False, help="Destination directory.")
57
+ url = Parameter(help="URL to fetch from.")
58
+ md5 = Parameter(required=False, help="Expected MD5 hash of the fetched file.")
59
+ sha256 = Parameter(required=False, help="Expected SHA256 hash of the fetched file.")
60
+
61
+ def __init__(self, *args, **kwargs):
62
+ super().__init__(*args, **kwargs)
63
+ self.joltdir = JoltLoader.get().joltdir
64
+
65
+ # Set the path to the extraction directory
66
+ if self.path.is_unset():
67
+ self.abspath = self.tools.builddir(utils.canonical(self.short_qualified_name), incremental="always", unique=False)
68
+ if not self._extract():
69
+ # Join with filename if not extracting
70
+ self.abspath = fs.path.join(self.abspath, self._get_filename())
71
+ else:
72
+ self.abspath = fs.path.join(self.joltdir, str(self.path) or self._get_name())
73
+
74
+ self.relpath = fs.path.relpath(self.abspath, self.tools.wsroot)
75
+
76
+ def _extract(self):
77
+ """ Check if the fetched file should/can be extracted. """
78
+ filename = self._get_filename()
79
+
80
+ if not any([filename.endswith(ext) for ext in SUPPORTED_ARCHIVE_TYPES]):
81
+ return False
82
+
83
+ return bool(self.extract)
84
+
85
+ def _acquire_ws(self):
86
+ # Create the destination directory if it does not exist
87
+ self.tools.rmtree(self.abspath, ignore_errors=True)
88
+ self.tools.mkdir(fs.path.dirname(self.abspath), recursively=True)
89
+
90
+ if self._extract():
91
+ with self.tools.tmpdir() as tmpdir, self.tools.cwd(tmpdir):
92
+ filename = self._get_filename()
93
+ self.tools.download(self.url, filename)
94
+ self._verify_sha256(filename)
95
+ self.tools.extract(filename, self.abspath)
96
+ else:
97
+ self.tools.download(self.url, self.abspath)
98
+ self._verify_sha256(self.abspath)
99
+
100
+ def acquire(self, artifact, deps, tools, owner):
101
+ self._acquire_ws()
102
+ self._assign_fetch(owner)
103
+ artifact.worktree = fs.path.relpath(self.abspath, owner.joltdir)
104
+
105
+ def _assign_fetch(self, task, none=False):
106
+ if not hasattr(task, "fetch"):
107
+ task.fetch = ErrorDict(self)
108
+ if none:
109
+ # None means the git repo is not cloned or checked out
110
+ # and should not be included in the git dictionary
111
+ # of the consuming task yet. If the consuming task
112
+ # requires the git repo for its influence collection,
113
+ # the dict will raise an error. The solution is to
114
+ # assign hash=true to the git requirement which
115
+ # will cause the git repo to be cloned and checked out
116
+ # before the influence collection is performed.
117
+ task.fetch[self._get_name()] = None
118
+ else:
119
+ # Assign the git repo to the consuming task.
120
+ # The git repo is cloned and checked out before
121
+ # any influence collection is performed.
122
+ task.fetch[self._get_name()] = fs.path.relpath(self.abspath, task.joltdir)
123
+
124
+ def _get_name(self):
125
+ return str(self.alias) if self.alias.is_set() else self._get_filename()
126
+
127
+ def _get_filename(self):
128
+ return fs.path.basename(str(self.url))
129
+
130
+ def _verify_sha256(self, filepath):
131
+ if not self.sha256.is_set():
132
+ return
133
+ actual_hash = self.tools.checksum_file(filepath, hashfn=hashlib.sha256)
134
+ expected_hash = str(self.sha256)
135
+ raise_error_if(
136
+ actual_hash != expected_hash,
137
+ f"SHA256 hash mismatch for fetched file '{filepath}': expected {expected_hash}, got {actual_hash}"
138
+ )
139
+
140
+
141
+ TaskRegistry.get().add_task_class(Fetch)
jolt/plugins/gdb.py CHANGED
@@ -1,7 +1,6 @@
1
1
  import click
2
2
  import os
3
3
  import sys
4
- import subprocess
5
4
 
6
5
  from jolt import cache
7
6
  from jolt import cli
@@ -9,6 +8,7 @@ from jolt import filesystem as fs
9
8
  from jolt import graph
10
9
  from jolt import log
11
10
  from jolt import scheduler
11
+ from jolt.error import raise_error
12
12
  from jolt.error import raise_task_error_if
13
13
  from jolt.hooks import TaskHookRegistry
14
14
  from jolt.options import JoltOptions
@@ -25,10 +25,11 @@ def stage_artifacts(artifacts, tools):
25
25
  tools.sandbox(artifact, incremental=True, reflect=fs.has_symlinks())
26
26
 
27
27
 
28
- def get_task_artifacts(task, artifact=None):
29
- acache = cache.ArtifactCache.get()
30
- artifact = artifact or acache.get_artifact(task)
31
- return artifact, [acache.get_artifact(dep) for dep in task.children]
28
+ def get_task_artifacts(task):
29
+ artifacts = []
30
+ for dep in task.children:
31
+ artifacts.extend(dep.artifacts)
32
+ return task.artifacts, artifacts
32
33
 
33
34
 
34
35
  @cli.cli.command(name="gdb", context_settings={"ignore_unknown_options": True})
@@ -69,36 +70,44 @@ def gdb(ctx, task, default, machine_interface, no_binary, gdb_args):
69
70
  if machine_interface:
70
71
  log.enable_gdb()
71
72
 
72
- manifest = ctx.obj["manifest"]
73
73
  options = JoltOptions(default=default)
74
74
  acache = cache.ArtifactCache.get(options)
75
75
  TaskHookRegistry.get(options)
76
76
  executors = scheduler.ExecutorRegistry.get(options)
77
77
  registry = TaskRegistry.get()
78
78
  strategy = scheduler.DownloadStrategy(executors, acache)
79
- queue = scheduler.TaskQueue(strategy)
79
+ queue = scheduler.TaskQueue()
80
80
 
81
81
  for params in default:
82
82
  registry.set_default_parameters(params)
83
83
 
84
- gb = graph.GraphBuilder(registry, manifest, options, progress=True)
84
+ gb = graph.GraphBuilder(registry, acache, options, progress=True)
85
85
  dag = gb.build([task])
86
86
 
87
87
  try:
88
88
  with log.progress("Progress", dag.number_of_tasks(), " tasks", estimates=False, debug=False) as p:
89
+ in_progress = set()
90
+
89
91
  while dag.has_tasks() or not queue.empty():
90
- leafs = dag.select(lambda graph, task: task.is_ready())
92
+ leafs = dag.select(lambda graph, task: task.is_ready() and task not in in_progress)
91
93
 
92
94
  while leafs:
93
95
  task = leafs.pop()
94
- queue.submit(acache, task)
96
+ executor = strategy.create_executor({}, task)
97
+ queue.submit(executor)
98
+ in_progress.add(task)
95
99
 
96
- task, error = queue.wait()
100
+ task, _ = queue.wait()
97
101
 
98
102
  # Materialize workspace resources so that
99
103
  # source code is available to the debugger.
100
104
  if isinstance(task.task, WorkspaceResource):
101
- task.task.acquire()
105
+ task.task.acquire_ws()
106
+
107
+ # Unpack the task if it is not a resource task and has a custom unpack method
108
+ if not task.is_resource():
109
+ if task.is_unpackable():
110
+ task.unpack()
102
111
 
103
112
  p.update(1)
104
113
 
@@ -107,27 +116,37 @@ def gdb(ctx, task, default, machine_interface, no_binary, gdb_args):
107
116
  log.warning("Interrupted by user")
108
117
  try:
109
118
  queue.abort()
119
+ executors.shutdown()
110
120
  sys.exit(1)
111
121
  except KeyboardInterrupt:
112
122
  print()
113
123
  log.warning("Interrupted again, exiting")
114
124
  os._exit(1)
125
+
115
126
  except Exception as e:
116
127
  log.set_interactive(True)
117
128
  raise e
118
129
 
130
+ finally:
131
+ queue.shutdown()
132
+
119
133
  assert len(dag.goals), "Too many tasks, can only debug one executable at a time"
120
134
 
121
135
  for goal in dag.goals:
122
- artifact, deps = get_task_artifacts(goal)
123
- stage_artifacts(deps + [artifact], goal.tools)
136
+ main, deps = get_task_artifacts(goal)
137
+ stage_artifacts(main + deps, goal.tools)
124
138
 
139
+ # Find an artifact with an executable
140
+ main = [artifact for artifact in main if artifact.strings.executable]
125
141
  raise_task_error_if(
126
- artifact.strings.executable.get_value() is None,
127
- goal, "No executable found in task artifact")
142
+ not main, goal, "No executable found in task artifact")
143
+ main = main[0]
128
144
 
129
145
  with acache.get_context(goal):
130
146
  gdb = goal.tools.getenv("GDB", "gdb")
147
+ gdb = goal.tools.which(gdb)
148
+ if not gdb:
149
+ raise_error("GDB not found in PATH")
131
150
  cmd = [gdb]
132
151
  sysroot = goal.tools.getenv("SDKTARGETSYSROOT", goal.tools.getenv("SYSROOT"))
133
152
  if sysroot:
@@ -141,13 +160,14 @@ def gdb(ctx, task, default, machine_interface, no_binary, gdb_args):
141
160
  cmd += ["-ex", "set print thread-events off"]
142
161
  cmd += ["-ex", "handle SIG32 nostop noprint"]
143
162
  if not no_binary:
144
- cmd += [os.path.join(artifact.path, str(artifact.strings.executable))]
163
+ cmd += [os.path.join(main.path, str(main.strings.executable))]
145
164
  cmd += gdb_args
146
165
 
147
166
  if isinstance(goal.task, ninja.CXXProject):
148
- cwd = goal.tools.builddir("ninja", incremental=True)
167
+ cwd = goal.tools.wsroot
149
168
  else:
150
169
  cwd = goal.task.joltdir
151
170
 
152
171
  with goal.tools.environ() as env:
153
- subprocess.call(cmd, env=env, cwd=cwd)
172
+ os.chdir(cwd)
173
+ os.execve(cmd[0], cmd, env)
jolt/plugins/gerrit.py CHANGED
@@ -7,18 +7,6 @@ from jolt.plugins import git
7
7
  log.verbose("[Gerrit] Loaded")
8
8
 
9
9
 
10
- class GerritSrc(git.GitSrc):
11
- name = "gerrit-src"
12
- url = Parameter(help="URL to the Gerrit git repo to be cloned. Required.")
13
- sha = Parameter(required=False, help="Specific commit or tag to be checked out. Optional.")
14
- path = Parameter(required=False, help="Local path where the repository should be cloned.")
15
- _revision = Export(value=lambda self: self._get_revision() or self.git.head())
16
-
17
- def __init__(self, *args, **kwargs):
18
- refspec1 = '+refs/changes/*:refs/remotes/origin/changes/*'
19
- super(GerritSrc, self).__init__(*args, refspecs=[refspec1], **kwargs)
20
-
21
-
22
10
  class Gerrit(git.Git):
23
11
  name = "gerrit"
24
12
  url = Parameter(help="URL to the Gerrit git repo to be cloned. Required.")
@@ -28,8 +16,7 @@ class Gerrit(git.Git):
28
16
 
29
17
  def __init__(self, *args, **kwargs):
30
18
  refspec1 = '+refs/changes/*:refs/remotes/origin/changes/*'
31
- super(Gerrit, self).__init__(*args, refspecs=[refspec1], **kwargs)
19
+ super().__init__(*args, refspecs=[refspec1], **kwargs)
32
20
 
33
21
 
34
- TaskRegistry.get().add_task_class(GerritSrc)
35
22
  TaskRegistry.get().add_task_class(Gerrit)