Chromium Code Reviews| Index: visual_studio/NativeClientVSAddIn/InstallerResources/create_ppapi_platform.py |
| diff --git a/visual_studio/NativeClientVSAddIn/InstallerResources/create_ppapi_platform.py b/visual_studio/NativeClientVSAddIn/InstallerResources/create_ppapi_platform.py |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..4662a381cec0e1cfd97eabe5ee7207cec7590015 |
| --- /dev/null |
| +++ b/visual_studio/NativeClientVSAddIn/InstallerResources/create_ppapi_platform.py |
| @@ -0,0 +1,181 @@ |
| +#!/usr/bin/env python |
| +# Copyright (c) 2012 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. |
| + |
| +""" This script creates the PPAPI project settings template. |
| + |
| +For copyright reasons, we should not directly distribute the PPAPI template |
| +because it is nearly a clone of the Win32 template which is Copyrighted. |
| +Instead, this script copies the existing Win32 template from the user's system |
| +and intelligently modifies the copy to be the PPAPI template. |
| +""" |
| + |
| +import pdb |
|
binji
2012/07/24 22:13:08
remove debugging code
tysand
2012/07/24 23:19:49
Done.
|
| +import os |
| +import shutil |
| +import string |
| +import xml_patch |
| +import xml.etree.ElementTree |
| + |
| +SCRIPT_DIR = os.path.dirname(os.path.abspath(__file__)) |
| + |
| +PLATFORM_FILES = [ |
| + ('Microsoft.Cpp.Win32.default.props', |
| + 'Microsoft.Cpp.[platform].default.props.patch', |
| + 'Microsoft.Cpp.PPAPI.default.props'), |
| + ('Microsoft.Cpp.Win32.props', |
| + 'Microsoft.Cpp.[platform].props.patch', |
| + 'Microsoft.Cpp.PPAPI.props'), |
| + ('Microsoft.Cpp.Win32.targets', |
| + 'Microsoft.Cpp.[platform].targets.patch', |
| + 'Microsoft.Cpp.PPAPI.targets'), |
| + ('PlatformToolsets\\v100\\Microsoft.Cpp.Win32.v100.props', |
| + 'PlatformToolsets\\v100\\Microsoft.Cpp.[platform].v100.props.patch', |
| + 'PlatformToolsets\\v100\\Microsoft.Cpp.PPAPI.v100.props'), |
| + ('PlatformToolsets\\v100\\Microsoft.Cpp.Win32.v100.targets', |
| + 'PlatformToolsets\\v100\\Microsoft.Cpp.[platform].v100.targets.patch', |
| + 'PlatformToolsets\\v100\\Microsoft.Cpp.PPAPI.v100.targets')] |
| + |
| +UI_FILES = [ |
| + ('general.xml', |
| + 'Props\\ppapi_general.xml.patch', |
| + 'Props\\ppapi_general.xml'), |
| + ('general_ps.xml', |
| + 'Props\\ppapi_general_ps.xml.patch', |
| + 'Props\\ppapi_general_ps.xml')] |
| + |
| +COPY_FILES = [ |
| + 'ImportAfter\\PPAPI.override.props'] |
| + |
| + |
| +def PrependCopyright(source_file_name, dest_file_name): |
| + """Adds the copyright notice from source file to the dest file. |
| + |
| + Since the patch_xml function does not read comments, the copyright is skipped |
| + during the initial copy. This function adds it back and also attaches a |
| + notice that the file was based on source_file_name and slightly modified. |
| + |
| + Args: |
| + source_file_name: The original Win32 file. |
| + dest_file_name: The existing PPAPI file. |
| + |
| + Returns: |
| + None. |
| + """ |
| + with open(source_file_name, 'r') as source_file: |
| + in_copyright = False |
| + copyright_notice = '' |
| + for line in source_file: |
| + if '<!--' in line: |
| + in_copyright = True |
| + if in_copyright: |
| + copyright_notice += line |
| + if '-->' in line: |
| + in_copyright = False |
| + break |
| + |
| + with open(dest_file_name, 'r') as original: |
| + xml_data = original.read() |
| + |
| + chrome_notice = ('<!-- This file has been copied and modified from %s during ' |
| + 'the installation process. -->\n\n' % (source_file_name)) |
| + |
| + with open(dest_file_name, 'w') as changed: |
| + changed.writelines(copyright_notice + chrome_notice + xml_data) |
| + |
| + |
| +def CreateTemplateFile(source, patch, dest): |
| + """Creates a single PPAPI template file. |
| + |
| + Args: |
| + source: The path source file to create from. |
| + patch: The path to the patch file to apply. |
| + dest: The path to the file to create. |
| + Returns: |
| + None. |
| + """ |
| + source_xml = xml.etree.ElementTree.parse(source) |
| + patch_xml = xml.etree.ElementTree.parse(patch) |
| + modified_xml = xml_patch.PatchXML(source_xml, patch_xml) |
| + |
| + if not os.path.exists(os.path.dirname(dest)): |
| + os.makedirs(os.path.dirname(dest)) |
| + |
| + FixAttributesNamespace(modified_xml) |
| + default_namespace = GetDefaultNamespace(modified_xml) |
| + modified_xml.write(dest, default_namespace=default_namespace) |
| + PrependCopyright(source, dest) |
| + |
| + |
| +def GetDefaultNamespace(tree): |
| + # Returns the uri (namespace identifier) of the root element. |
| + tag = tree.getroot().tag |
| + if tag[:1] == "{": |
|
binji
2012/07/24 22:13:08
nice trick, tag[:1] is the same as tag[0] but it w
tysand
2012/07/24 23:19:49
Changed this to tag.startswith("{") following your
|
| + uri, rest = tag[1:].rsplit("}", 1) |
| + return uri |
| + else: |
| + return None |
| + |
| + |
| +def FixAttributesNamespace(tree): |
| + # ElementTree's implementation seems to be broken in that attributes |
| + # do not inherit the default namespace of their node or parent nodes. |
| + # This causes issues with ElementTree.write() when using a default namespace. |
| + # Since the attributes do not have a namespace, the code that collects a |
| + # mapping between local names and qualified names (with a namespace) breaks. |
| + # The work-around is to give all attributes the default namespace. |
| + default_namespace = GetDefaultNamespace(tree) |
| + for elem in tree.getroot().getiterator(): |
| + new_attrib = dict() |
| + for key, value in elem.attrib.items(): |
| + # If the attribute does not have a namespace yet then give it one. |
| + if key[:1] != "{": |
| + new_key = "{%s}%s" % (default_namespace, key) |
| + new_attrib[new_key] = value |
| + else: |
| + new_attrib[key] = value |
| + elem.attrib = new_attrib |
| + |
| + |
| +def main(): |
| + install_dir = os.path.expandvars( |
| + '%ProgramFiles(x86)%\\MSBuild\\Microsoft.Cpp\\v4.0\\Platforms') |
| + |
| + # Note 1033 is code for the english language. |
| + ui_xml_dir = os.path.expandvars( |
| + '%ProgramFiles(x86)%\\MSBuild\\Microsoft.Cpp\\v4.0\\1033') |
| + |
| + win32_dir = os.path.join(install_dir, 'Win32') |
| + ppapi_dir = os.path.join(install_dir, 'PPAPI') |
| + patch_dir = os.path.join(SCRIPT_DIR, 'PPAPI_Patch') |
| + |
| + if not os.path.exists(win32_dir): |
| + raise Exception('Win32 platform is not installed on this machine!') |
| + |
| + for template_creation in PLATFORM_FILES: |
| + CreateTemplateFile( |
| + os.path.join(win32_dir, template_creation[0]), |
| + os.path.join(patch_dir, template_creation[1]), |
| + os.path.join(ppapi_dir, template_creation[2])) |
| + |
| + for template_creation in UI_FILES: |
| + CreateTemplateFile( |
| + os.path.join(ui_xml_dir, template_creation[0]), |
| + os.path.join(patch_dir, template_creation[1]), |
| + os.path.join(ppapi_dir, template_creation[2])) |
| + |
| + for file_name in COPY_FILES: |
| + copy_from = os.path.join(patch_dir, file_name) |
| + copy_to = os.path.join(ppapi_dir, file_name) |
| + if not os.path.exists(os.path.dirname(copy_to)): |
| + os.makedirs(os.path.dirname(copy_to)) |
| + shutil.copyfile(copy_from, copy_to) |
| + |
| + shutil.copyfile( |
| + os.path.join(win32_dir, 'Microsoft.Build.CPPTasks.Win32.dll'), |
| + os.path.join(ppapi_dir, 'Microsoft.Build.CPPTasks.PPAPI.dll')) |
| + |
| + |
| +if __name__ == '__main__': |
| + main() |