Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(16)

Side by Side Diff: build/android/gyp/XmlLayoutCopyMirror.py

Issue 14476011: [Android] Auto-generate API 14 resources from the existing API 17 resources. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 #!/usr/bin/env python
newt (away) 2013/04/24 23:34:38 copyright also, this filename should be in unders
Kibeom Kim (inactive) 2013/04/25 00:04:39 Done.
2
3 import optparse
4 import os
5 import xml.etree.cElementTree as ET
6
7 from util import build_utils
8
9 pre = '{http://schemas.android.com/apk/res/android}'
newt (away) 2013/04/24 23:34:38 constants should be in ALL_CAPS. also, I'd give th
Kibeom Kim (inactive) 2013/04/25 00:04:39 Done.
10
11 s = ('paddingLeft',
12 'drawableLeft',
newt (away) 2013/04/24 23:34:38 add more spaces to line these up with 'paddingLeft
Kibeom Kim (inactive) 2013/04/25 00:04:39 Done.
13 'layout_alignLeft',
14 'layout_marginLeft',
15 'layout_alignParentLeft',
16 'layout_toLeftOf',
17 'paddingRight',
18 'drawableRight',
19 'layout_alignRight',
20 'layout_marginRight',
21 'layout_alignParentRight',
22 'layout_toRightOf',
23 'gravity',
24 'layout_gravity')
25
26 s = set((pre + i for i in s))
27
28 def reverse_xml(input_filename, output_filename):
29 """
30 """
31 tree = ET.parse(input_filename)
32 for element in tree.iter():
33 directional_attributes = s.intersection(element.keys())
34 new_attributes_to_override = {}
35 for directional_attribute in directional_attributes:
36 if 'Left' in directional_attribute:
37 new_attributes_to_override[directional_attribute.replace('Left', 'Right' )] = element.attrib[directional_attribute]
38 elif 'Right' in directional_attribute:
39 new_attributes_to_override[directional_attribute.replace('Right', 'Left' )] = element.attrib[directional_attribute]
40 else: # Either gravity or layout_gravity
41 new_attributes_to_override[directional_attribute] = \
42 element.attrib[directional_attribute].replace('left', 'XXX').replace ('right', 'left').replace('XXX', 'right')
newt (away) 2013/04/24 23:34:38 it'd be nice to avoid using XXX like this, e.g.:
Kibeom Kim (inactive) 2013/04/25 00:04:39 I haven't used regex much, but this simple thing l
43 element.attrib.update(new_attributes_to_override)
44 output_dir = os.path.dirname(output_filename)
45 if not os.path.exists(output_dir):
newt (away) 2013/04/24 23:34:38 build_utils.MakeDirectory(output_dir)
Kibeom Kim (inactive) 2013/04/25 00:04:39 Done.
46 os.makedirs(output_dir)
47 tree.write(output_filename, encoding='utf-8', xml_declaration=True)
48
49 def reverse_all_xml_in_dir(input_dir, output_dir):
50 """
51 """
52 for root, dirs, files in os.walk(input_dir, followlinks=True):
53 relative_dir = os.path.relpath(root, input_dir)
54 for f in files:
55 if f.lower().endswith('.xml'):
56 input_filename = os.path.join(input_dir, relative_dir, f)
57 output_filename = os.path.join(output_dir, relative_dir, f)
58 reverse_xml(input_filename, output_filename)
59
60 def ParseArgs():
61 """Parses command line options.
62
63 Returns:
64 An options object as from optparse.OptionsParser.parse_args()
65 """
66 parser = optparse.OptionParser()
67 parser.add_option('--res-dir',
68 help='directory containing resources to be reversed')
69 parser.add_option('--res-ldrtl-dir',
70 help='directory containing resources to be generated')
71
72 (options, args) = parser.parse_args()
73
74 if args:
75 parser.error('No positional arguments should be given.')
76
77 # Check that required options have been provided.
78 required_options = ('res_dir', 'res_ldrtl_dir')
79 build_utils.CheckOptions(options, parser, required=required_options)
80
81 return options
82
83 def main():
84 options = ParseArgs()
85 res_sub_dirs = os.walk(options.res_dir).next()[1]
86
87 for res_sub_dir in res_sub_dirs:
88 if '-ldrtl' in res_sub_dir:
89 continue
90 if (not res_sub_dir.startswith('layout') and \
91 not res_sub_dir.startswith('xml')):
92 continue
93 res_sub_dir_split = res_sub_dir.split('-')
94 res_sub_dir_split.insert(1, 'ldrtl')
95 res_ldrtl_sub_dir = '-'.join(res_sub_dir_split)
96 reverse_all_xml_in_dir(os.path.join(options.res_dir, res_sub_dir), \
97 os.path.join(options.res_ldrtl_dir, res_ldrtl_sub_dir ))
98
99 if __name__ == '__main__':
100 main()
OLDNEW
« no previous file with comments | « no previous file | build/android/gyp/process_resources.py » ('j') | build/android/gyp/process_resources.py » ('J')

Powered by Google App Engine
This is Rietveld 408576698