OLD | NEW |
(Empty) | |
| 1 # HG changeset patch |
| 2 # User Felix Dahlke <felix@adblockplus.org> |
| 3 # Date 1431547667 -7200 |
| 4 # Wed May 13 22:07:47 2015 +0200 |
| 5 # Node ID 7e0cd0610aecdfe47450a26ae6e13c81fcb60d81 |
| 6 # Parent ae1c968784024553c3a2eaf4c446757798be7e13 |
| 7 Issue 2510 - Support Adblock Browser |
| 8 |
| 9 diff -r ae1c96878402 -r 7e0cd0610aec chrome.manifest |
| 10 --- a/chrome.manifest Tue May 12 23:01:08 2015 +0200 |
| 11 +++ b/chrome.manifest Wed May 13 22:07:47 2015 +0200 |
| 12 @@ -3,4 +3,4 @@ |
| 13 locale adblockplus {{LOCALE}} chrome/locale/{{LOCALE}}/ |
| 14 |
| 15 # fennec settings |
| 16 -override chrome://adblockplus/content/ui/settings.xul chrome://adblockplus/cont
ent/ui/fennecSettings.xul application={a23983c0-fd0e-11dc-95ff-0800200c9a66} app
lication={aa3c5121-dab2-40e2-81ca-7ea25febc110} |
| 17 +override chrome://adblockplus/content/ui/settings.xul chrome://adblockplus/cont
ent/ui/fennecSettings.xul application={a23983c0-fd0e-11dc-95ff-0800200c9a66} app
lication={aa3c5121-dab2-40e2-81ca-7ea25febc110} application={55aba3ac-94d3-41a8-
9e25-5c21fe874539} |
| 18 diff -r ae1c96878402 -r 7e0cd0610aec dependencies |
| 19 --- a/dependencies Tue May 12 23:01:08 2015 +0200 |
| 20 +++ b/dependencies Wed May 13 22:07:47 2015 +0200 |
| 21 @@ -1,4 +1,4 @@ |
| 22 _root = hg:https://hg.adblockplus.org/ git:https://github.com/adblockplus/ |
| 23 _self = buildtools/ensure_dependencies.py |
| 24 -buildtools = buildtools hg:97e2e12af6e8 git:ef69bbc |
| 25 +buildtools = buildtools hg:f9f01a4c16af git: |
| 26 adblockplusui = adblockplusui hg:75a50600e10a git:7ebacdc |
| 27 diff -r ae1c96878402 -r 7e0cd0610aec ensure_dependencies.py |
| 28 --- a/ensure_dependencies.py Tue May 12 23:01:08 2015 +0200 |
| 29 +++ b/ensure_dependencies.py Wed May 13 22:07:47 2015 +0200 |
| 30 @@ -34,6 +34,10 @@ |
| 31 buildtools = buildtools hg:016d16f7137b git:f3f8692f82e5 |
| 32 """ |
| 33 |
| 34 +SKIP_DEPENDENCY_UPDATES = os.environ.get( |
| 35 + "SKIP_DEPENDENCY_UPDATES", "" |
| 36 +).lower() not in ("", "0", "false") |
| 37 + |
| 38 class Mercurial(): |
| 39 def istype(self, repodir): |
| 40 return os.path.exists(os.path.join(repodir, ".hg")) |
| 41 @@ -97,7 +101,20 @@ |
| 42 return subprocess.check_output(command, cwd=repo).strip() |
| 43 |
| 44 def pull(self, repo): |
| 45 + # Fetch tracked branches, new tags and the list of available remote branche
s |
| 46 subprocess.check_call(["git", "fetch", "--quiet", "--all", "--tags"], cwd=r
epo) |
| 47 + # Next we need to ensure all remote branches are tracked |
| 48 + newly_tracked = False |
| 49 + remotes = subprocess.check_output(["git", "branch", "--remotes"], cwd=repo) |
| 50 + for match in re.finditer(r"^\s*(origin/(\S+))$", remotes, re.M): |
| 51 + remote, local = match.groups() |
| 52 + with open(os.devnull, "wb") as devnull: |
| 53 + if subprocess.call(["git", "branch", "--track", local, remote], |
| 54 + cwd=repo, stdout=devnull, stderr=devnull) == 0: |
| 55 + newly_tracked = True |
| 56 + # Finally fetch any newly tracked remote branches |
| 57 + if newly_tracked: |
| 58 + subprocess.check_call(["git", "fetch", "--quiet", "origin"], cwd=repo) |
| 59 |
| 60 def update(self, repo, rev): |
| 61 subprocess.check_call(["git", "checkout", "--quiet", rev], cwd=repo) |
| 62 @@ -167,7 +184,7 @@ |
| 63 |
| 64 def safe_join(path, subpath): |
| 65 # This has been inspired by Flask's safe_join() function |
| 66 - forbidden = set([os.sep, os.altsep]) - set([posixpath.sep, None]) |
| 67 + forbidden = {os.sep, os.altsep} - {posixpath.sep, None} |
| 68 if any(sep in subpath for sep in forbidden): |
| 69 raise Exception("Illegal directory separator in dependency path %s" % subpa
th) |
| 70 |
| 71 @@ -188,6 +205,11 @@ |
| 72 if os.path.exists(target): |
| 73 return |
| 74 |
| 75 + if SKIP_DEPENDENCY_UPDATES: |
| 76 + logging.warning("SKIP_DEPENDENCY_UPDATES environment variable set, " |
| 77 + "%s not cloned", target) |
| 78 + return |
| 79 + |
| 80 parenttype = get_repo_type(parentrepo) |
| 81 type = None |
| 82 for key in roots: |
| 83 @@ -227,15 +249,21 @@ |
| 84 return |
| 85 |
| 86 resolved_revision = repo_types[type].get_revision_id(target, revision) |
| 87 - if not resolved_revision: |
| 88 - logging.info("Revision %s is unknown, downloading remote changes" % revisio
n) |
| 89 - repo_types[type].pull(target) |
| 90 - resolved_revision = repo_types[type].get_revision_id(target, revision) |
| 91 + current_revision = repo_types[type].get_revision_id(target) |
| 92 + |
| 93 + if resolved_revision != current_revision: |
| 94 + if SKIP_DEPENDENCY_UPDATES: |
| 95 + logging.warning("SKIP_DEPENDENCY_UPDATES environment variable set, " |
| 96 + "%s not checked out to %s", target, revision) |
| 97 + return |
| 98 + |
| 99 if not resolved_revision: |
| 100 - raise Exception("Failed to resolve revision %s" % revision) |
| 101 + logging.info("Revision %s is unknown, downloading remote changes" % revis
ion) |
| 102 + repo_types[type].pull(target) |
| 103 + resolved_revision = repo_types[type].get_revision_id(target, revision) |
| 104 + if not resolved_revision: |
| 105 + raise Exception("Failed to resolve revision %s" % revision) |
| 106 |
| 107 - current_revision = repo_types[type].get_revision_id(target) |
| 108 - if resolved_revision != current_revision: |
| 109 logging.info("Updating repository %s to revision %s" % (target, resolved_re
vision)) |
| 110 repo_types[type].update(target, resolved_revision) |
| 111 |
| 112 @@ -247,6 +275,7 @@ |
| 113 return |
| 114 if level >= 10: |
| 115 logging.warning("Too much subrepository nesting, ignoring %s" % repo) |
| 116 + return |
| 117 |
| 118 if overrideroots is not None: |
| 119 config["_root"] = overrideroots |
| 120 diff -r ae1c96878402 -r 7e0cd0610aec lib/appSupport.js |
| 121 --- a/lib/appSupport.js Tue May 12 23:01:08 2015 +0200 |
| 122 +++ b/lib/appSupport.js Wed May 13 22:07:47 2015 +0200 |
| 123 @@ -690,6 +690,7 @@ |
| 124 } |
| 125 |
| 126 case "fennec2": |
| 127 + case "adblockbrowser": |
| 128 { |
| 129 exports.isKnownWindow = (window) => window.document.documentElement.id == "
main-window"; |
| 130 |
| 131 diff -r ae1c96878402 -r 7e0cd0610aec lib/objectTabs.js |
| 132 --- a/lib/objectTabs.js Tue May 12 23:01:08 2015 +0200 |
| 133 +++ b/lib/objectTabs.js Wed May 13 22:07:47 2015 +0200 |
| 134 @@ -178,7 +178,8 @@ |
| 135 { |
| 136 // Object tabs aren't usable in Fennec |
| 137 let {application} = require("info"); |
| 138 - if (application == "fennec" || application == "fennec2") |
| 139 + if (application == "fennec" || application == "fennec2" || |
| 140 + application == "adblockbrowser") |
| 141 return; |
| 142 |
| 143 let {Prefs} = require("prefs"); |
| 144 diff -r ae1c96878402 -r 7e0cd0610aec metadata.gecko |
| 145 --- a/metadata.gecko Tue May 12 23:01:08 2015 +0200 |
| 146 +++ b/metadata.gecko Wed May 13 22:07:47 2015 +0200 |
| 147 @@ -34,6 +34,7 @@ |
| 148 thunderbird=29.0/39.0 |
| 149 seamonkey=2.26/2.36 |
| 150 toolkit=29.0/39.0 |
| 151 +adblockbrowser=1.0/1.0 |
| 152 |
| 153 [mapping] |
| 154 chrome/content/ui/firstRun.html = adblockplusui/firstRun.html |
OLD | NEW |