Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Side by Side Diff: localeTools.py

Issue 29611593: Issue 5996 - Release consistent versions across WebExtensions (Closed) Base URL: https://codereview.adblockplus.org/29609559/
Patch Set: Rebase against https://hg.adblockplus.org/buildtools/rev/f92050874f05 Created Nov. 20, 2017, 2:43 p.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | Download patch
« no previous file with comments | « build.py ('k') | packager.py » ('j') | releaseAutomation.py » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # This Source Code Form is subject to the terms of the Mozilla Public 1 # This Source Code Form is subject to the terms of the Mozilla Public
2 # License, v. 2.0. If a copy of the MPL was not distributed with this 2 # License, v. 2.0. If a copy of the MPL was not distributed with this
3 # file, You can obtain one at http://mozilla.org/MPL/2.0/. 3 # file, You can obtain one at http://mozilla.org/MPL/2.0/.
4 4
5 import re 5 import re
6 import os 6 import os
7 import sys 7 import sys
8 import codecs 8 import codecs
9 import json 9 import json
10 import urlparse 10 import urlparse
(...skipping 23 matching lines...) Expand all
34 'sv': 'sv-SE', 34 'sv': 'sv-SE',
35 'ur': 'ur-PK', 35 'ur': 'ur-PK',
36 } 36 }
37 37
38 CROWDIN_AP_URL = 'https://api.crowdin.com/api/project' 38 CROWDIN_AP_URL = 'https://api.crowdin.com/api/project'
39 FIREFOX_RELEASES_URL = 'http://www.mozilla.org/en-US/firefox/all.html' 39 FIREFOX_RELEASES_URL = 'http://www.mozilla.org/en-US/firefox/all.html'
40 FIREFOX_LP_URL = 'https://addons.mozilla.org/en-US/firefox/language-tools/' 40 FIREFOX_LP_URL = 'https://addons.mozilla.org/en-US/firefox/language-tools/'
41 CHROMIUM_DEB_URL = 'https://packages.debian.org/sid/all/chromium-l10n/filelist' 41 CHROMIUM_DEB_URL = 'https://packages.debian.org/sid/all/chromium-l10n/filelist'
42 42
43 43
44 def read_locale_config(baseDir, platform, metadata):
45 if platform != 'generic':
46 import buildtools.packagerChrome as packager
47 localeDir = os.path.join(baseDir, '_locales')
48 localeConfig = {
49 'default_locale': packager.defaultLocale,
50 }
51 else:
52 localeDir = os.path.join(
53 baseDir, *metadata.get('locales', 'base_path').split('/')
54 )
55 localeConfig = {
56 'default_locale': metadata.get('locales', 'default_locale')
57 }
58
59 localeConfig['base_path'] = localeDir
60
61 locales = [(locale.replace('_', '-'), os.path.join(localeDir, locale))
62 for locale in os.listdir(localeDir)]
63 localeConfig['locales'] = dict(locales)
64
65 return localeConfig
66
67
44 def crowdin_request(project_name, action, key, get={}, post_data=None, 68 def crowdin_request(project_name, action, key, get={}, post_data=None,
45 headers={}, raw=False): 69 headers={}, raw=False):
46 """Perform a call to crowdin and raise an Exception on failure.""" 70 """Perform a call to crowdin and raise an Exception on failure."""
47 request = urllib2.Request( 71 request = urllib2.Request(
48 '{}/{}/{}?{}'.format(CROWDIN_AP_URL, 72 '{}/{}/{}?{}'.format(CROWDIN_AP_URL,
49 urllib.quote(project_name), 73 urllib.quote(project_name),
50 urllib.quote(action), 74 urllib.quote(action),
51 urllib.urlencode(dict(get, key=key, json=1))), 75 urllib.urlencode(dict(get, key=key, json=1))),
52 post_data, 76 post_data,
53 headers, 77 headers,
(...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after
294 # Remove any extra files 318 # Remove any extra files
295 for dir, files in dirs.iteritems(): 319 for dir, files in dirs.iteritems():
296 baseDir = os.path.join(localeConfig['base_path'], dir) 320 baseDir = os.path.join(localeConfig['base_path'], dir)
297 if not os.path.exists(baseDir): 321 if not os.path.exists(baseDir):
298 continue 322 continue
299 for file in os.listdir(baseDir): 323 for file in os.listdir(baseDir):
300 path = os.path.join(baseDir, file) 324 path = os.path.join(baseDir, file)
301 valid_extension = file.endswith('.json') 325 valid_extension = file.endswith('.json')
302 if os.path.isfile(path) and valid_extension and not file in files: 326 if os.path.isfile(path) and valid_extension and not file in files:
303 os.remove(path) 327 os.remove(path)
OLDNEW
« no previous file with comments | « build.py ('k') | packager.py » ('j') | releaseAutomation.py » ('J')

Powered by Google App Engine
This is Rietveld