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

Unified Diff: build/android/gyp/generate_v14_resources.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: Fixed Newton's comment. Investigating warnings. 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 side-by-side diff with in-line comments
Download patch
Index: build/android/gyp/generate_v14_resources.py
diff --git a/build/android/gyp/generate_v14_resources.py b/build/android/gyp/generate_v14_resources.py
new file mode 100755
index 0000000000000000000000000000000000000000..2936b7e539bd5103e48d59ddaeb70b3e182290ae
--- /dev/null
+++ b/build/android/gyp/generate_v14_resources.py
@@ -0,0 +1,170 @@
+#!/usr/bin/env python
+#
+# Copyright 2013 The Chromium Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style license that can be
+# found in the LICENSE file.
+
+import optparse
+import os
+import re
+import sys
+import xml.dom.minidom as minidom
+
+from util import build_utils
+
+
+ATTRIBUTE_NAMESPACE = u'http://schemas.android.com/apk/res/android'
+
+# The list of the attributes were taken from go/android-rtl
+ATTRIBUTES_TO_MAP = {'paddingStart' : 'paddingLeft',
+ 'drawableStart' : 'drawableLeft',
+ 'layout_alignStart' : 'layout_alignLeft',
+ 'layout_marginStart' : 'layout_marginLeft',
+ 'layout_alignParentStart' : 'layout_alignParentLeft',
+ 'layout_toStartOf' : 'layout_toLeftOf',
+ 'paddingEnd' : 'paddingRight',
+ 'drawableEnd' : 'drawableRight',
+ 'layout_alignEnd' : 'layout_alignRight',
+ 'layout_marginEnd' : 'layout_marginRight',
+ 'layout_alignParentEnd' : 'layout_alignParentRight',
+ 'layout_toEndOf' : 'layout_toRightOf'}
+
+ATTRIBUTES_TO_MAP_NS = {}
+
+for k, v in ATTRIBUTES_TO_MAP.items():
+ ATTRIBUTES_TO_MAP_NS[(ATTRIBUTE_NAMESPACE, k)] = (ATTRIBUTE_NAMESPACE , v)
newt (away) 2013/04/26 21:22:24 remove space before comma
cjhopman 2013/04/26 21:50:00 Also, remove one space after first comma
Kibeom Kim (inactive) 2013/04/27 00:05:07 Done.
Kibeom Kim (inactive) 2013/04/27 00:05:07 Done.
+
+
+def iterate_xml_elements(node):
+ """minidom helper function that iterates all the element nodes. Depth-first.
+ """
+ if node.nodeType == node.ELEMENT_NODE:
+ yield node
+ for child_node in node.childNodes:
+ for child_node_element in iterate_xml_elements(child_node):
+ yield child_node_element
+
+
+def generate_pre_v17_resource(input_filename, output_filename):
+ """Convert resource to API 14 compatible resource.
+
+ It's mostly a simple replacement, s/Start/Left s/End/Right,
+ on the attribute names.
+ """
+ dom = minidom.parse(input_filename)
+
+ for element in iterate_xml_elements(dom):
+ all_names = element.attributes.keysNS()
+
+ # Iterate all the attributes to find attributes to convert.
+ # Note that name variable is actually a tuple that has namespace and name.
+ # For example,
+ # name == ('http://schemas.android.com/apk/res/android', 'paddingStart')
+ for name, value in list(element.attributes.itemsNS()):
newt (away) 2013/04/26 21:22:24 you should be able to remove "list"
Kibeom Kim (inactive) 2013/04/27 00:05:07 Is it ok? I have del element.attributes[name] in t
+ # Note: gravity attributes are not necessary to convert because
+ # start/end values are backward-compatible. Explained at
+ # https://plus.sandbox.google.com/+RomanNurik/posts/huuJd8iVVXY?e=Showroom
+
+ # Convert any other API 17 Start/End attributes to Left/Right attributes.
+ # For example, from paddingStart="10dp" to paddingLeft="10dp"
+ if name in ATTRIBUTES_TO_MAP_NS:
+ mapped_name = ATTRIBUTES_TO_MAP_NS[name]
+
+ # Add the new mapped attribute and remove the original attribute.
+ # For example, add paddingLeft and remove paddingStart.
+ element.setAttributeNS(mapped_name[0], mapped_name[1], value)
+ del element.attributes[name]
+ elif name in ATTRIBUTES_TO_MAP.values():
newt (away) 2013/04/26 21:22:24 ATTRIBUTES_TO_MAP_NS also, not sure how long this
Kibeom Kim (inactive) 2013/04/27 00:05:07 Done.
+ # TODO(kkimlabs): Enable warning once layouts have been converted
+ # print >> sys.stderror, 'Warning: layout should use xxx instead of yyy'
+ pass
+
+ build_utils.MakeDirectory(os.path.dirname(output_filename))
+ dom.writexml(open(output_filename,"w"), ' ', '\n')
newt (away) 2013/04/26 21:22:24 be sure to close these files! :) with open(ou
Kibeom Kim (inactive) 2013/04/27 00:05:07 Done.
+
+
+def generate_v14_resources_in_dir(input_dir, output_dir):
+ """Convert resources to API 14 compatible resources in the directory.
+ """
+
+ for name in os.listdir(options.res_dir):
+ if not os.path.isfile(name):
+ continue
+
+ if not name.lower().endswith('.xml'):
+ continue
+
+ input_filename = os.path.join(input_dir, name)
+ output_filename = os.path.join(output_dir, name)
+ generate_pre_v17_resource(input_filename, output_filename)
+
+
+def ParseArgs():
+ """Parses command line options.
+
+ Returns:
+ An options object as from optparse.OptionsParser.parse_args()
+ """
+ parser = optparse.OptionParser()
+ parser.add_option('--res-dir',
+ help='directory containing resources '
+ 'be used to generate v14 resources')
newt (away) 2013/04/26 21:22:24 oops.. remove "be"
Kibeom Kim (inactive) 2013/04/27 00:05:07 Done.
+ parser.add_option('--res-v14-dir',
+ help='directory containing v14 resources to be generated')
newt (away) 2013/04/26 21:22:24 "output directory into which v14 resources will be
Kibeom Kim (inactive) 2013/04/27 00:05:07 Done.
+
+ (options, args) = parser.parse_args()
+
+ if args:
+ parser.error('No positional arguments should be given.')
+
+ # Check that required options have been provided.
+ required_options = ('res_dir', 'res_v14_dir')
+ build_utils.CheckOptions(options, parser, required=required_options)
+ return options
+
+
+def main(argv):
newt (away) 2013/04/26 21:22:24 we should probably delete the output directory bef
Kibeom Kim (inactive) 2013/04/27 00:05:07 Done.
+ """Convert Android xml resources to API 14 compatible.
+
+ There are two reasons that we cannot just use API attributes,
+ so we are generating another set of resources by this script.
+
+ 1. paddingStart attribute can cause a crash on Galaxy Tab 2. b/8351339
+ 2. There is a bug that paddingStart does not override paddingLeft on
+ JB-MR1 b/8654490 . This is fixed on JB-MR2.
+
+ Therefore, this resource generation script can be removed when
+ we drop the support for JB-MR1.
+
+ Please refer to crbug.com/235118 for the details.
+ """
+
+ options = ParseArgs()
+
+ build_utils.MakeDirectory(options.res_v14_dir)
+
+ for name in os.listdir(options.res_dir):
+ if not os.path.isdir(name):
+ continue
+
+ dir_pieces = name.split('-')
+ resource_type = dir_pieces[0]
+ qualifiers = dir_pieces[1:]
+
+ # We only convert resources under layout*/ and xml*/.
+ if resource_type not in ('layout', 'xml'):
+ continue
+
+ # Android pre-v17 API doesn't support RTL. Skip.
+ if 'ldrtl' in qualifiers:
+ continue
+
+ # Convert all the resource files.
+ input_path = os.path.join(options.res_dir, name)
+ output_path = os.path.join(options.res_v14_dir, name)
+ generate_v14_resources_in_dir(input_path, output_path)
+
+
+if __name__ == '__main__':
+ sys.exit(main(sys.argv))
+

Powered by Google App Engine
This is Rietveld 408576698