0
Fork 0
mirror of https://codeberg.org/librewolf/source.git synced 2025-01-05 04:10:08 -05:00
LibreWolf/patches/bootstrap.patch

125 lines
4.8 KiB
Diff
Raw Normal View History

2023-07-09 09:35:46 -05:00
# Upstream Bug
--- a/python/mozversioncontrol/mozversioncontrol/__init__.py
+++ b/python/mozversioncontrol/mozversioncontrol/__init__.py
@@ -828,7 +828,7 @@ class SrcRepository(Repository):
"""
res = []
# move away the .git or .hg folder from path to more easily test in a hg/git repo
- for root, dirs, files in os.walk("."):
+ for root, dirs, files in os.walk(path):
for name in files:
res.append(os.path.join(root, name))
return res
@@ -841,7 +841,9 @@ class SrcRepository(Repository):
import fnmatch
files = list(
- p.replace("\\", "/").replace("./", "") for p in self.get_files(path) if p
+ (os.path.relpath(p, path)).replace("\\", "/")
+ for p in self.get_files(path)
+ if p
)
files.sort()
ig = self.git_ignore(path)
# These changes have accidentally been reverted upstream
--- a/third_party/python/taskcluster_taskgraph/taskgraph/generator.py
+++ b/third_party/python/taskcluster_taskgraph/taskgraph/generator.py
@@ -269,11 +269,11 @@
filters = parameters.get("filters", [])
# Always add legacy target tasks method until we deprecate that API.
if "target_tasks_method" not in filters:
filters.insert(0, "target_tasks_method")
- filters = [filter_tasks.filter_task_functions[f] for f in filters]
+ filters = [filter_tasks.filter_task_functions[f] for f in filters if f]
yield self.verify("parameters", parameters)
logger.info("Loading kinds")
# put the kinds into a graph and sort topologically so that kinds are loaded
--- a/third_party/python/taskcluster_taskgraph/taskgraph/parameters.py
+++ b/third_party/python/taskcluster_taskgraph/taskgraph/parameters.py
2023-10-27 02:45:04 -05:00
@@ -83,9 +83,36 @@ def _get_defaults(repo_root=None):
try:
repo = get_repository(repo_path)
except RuntimeError:
- # Use fake values if no repo is detected.
- repo = Mock(branch="", head_rev="", tool="git")
- repo.get_url.return_value = ""
+ # patches/bootstrap.patch - return our object from here, but
+ # it's possible the mock object would have sufficed.
2023-07-09 09:35:46 -05:00
+ return {
+ "base_repository": "SOURCE",
+ "base_ref": "",
+ "base_rev": "",
+ "build_date": int(time.time()),
+ "build_number": 1,
+ "do_not_optimize": [],
+ "enable_always_target": True,
+ "existing_tasks": {},
+ "filters": ["target_tasks_method"],
+ "head_ref": "",
+ "head_repository": "",
+ "head_rev": "",
+ "head_tag": "",
+ "level": "3",
+ "moz_build_date": datetime.now().strftime("%Y%m%d%H%M%S"),
+ "next_version": None,
+ "optimize_strategies": None,
+ "optimize_target_tasks": True,
+ "owner": "nobody@mozilla.com",
+ "project": "",
+ "pushdate": int(time.time()),
+ "pushlog_id": "0",
+ "repository_type": "",
+ "target_tasks_method": "default",
+ "tasks_for": "",
+ "version": "",
+ }
2023-10-27 02:45:04 -05:00
try:
repo_url = repo.get_url()
2023-07-09 09:35:46 -05:00
@@ -193,17 +223,18 @@
return os.path.splitext(os.path.basename(spec))[0]
@staticmethod
def _fill_defaults(repo_root=None, **kwargs):
defaults = {}
- for fn in defaults_functions:
- defaults.update(fn(repo_root))
+ if repo_root != "SOURCE":
+ for fn in defaults_functions:
+ defaults.update(fn(repo_root))
- for name, default in defaults.items():
- if name not in kwargs:
- kwargs[name] = default
- return kwargs
+ for name, default in defaults.items():
+ if name not in kwargs:
+ kwargs[name] = default
+ return kwargs
def check(self):
schema = (
base_schema if self.strict else base_schema.extend({}, extra=ALLOW_EXTRA)
)
--- a/third_party/python/taskcluster_taskgraph/taskgraph/util/vcs.py
+++ b/third_party/python/taskcluster_taskgraph/taskgraph/util/vcs.py
@@ -502,12 +502,14 @@
for path in ancestors(path):
if os.path.isdir(os.path.join(path, ".hg")):
return HgRepository(path)
elif os.path.exists(os.path.join(path, ".git")):
return GitRepository(path)
+ elif os.path.exists(os.path.join(path, "moz.configure")):
+ return None
- raise RuntimeError("Current directory is neither a git or hg repository")
+ raise RuntimeError("Current directory is neither a git or hg repository, nor a release source")
def find_hg_revision_push_info(repository, revision):
"""Given the parameters for this action and a revision, find the
pushlog_id of the revision."""