Delete XML string manipulation code.

pull/2300/head
Jussi Pakkanen 8 years ago
parent 048d941e95
commit 41805f1b31
  1. 90
      msi/createmsi.py

@ -22,50 +22,6 @@ import xml.etree.ElementTree as ET
sys.path.append(os.getcwd())
from mesonbuild import coredata
xml_templ = '''<?xml version='1.0' encoding='windows-1252'?>
<Wix xmlns='http://schemas.microsoft.com/wix/2006/wi'>
<Product Name='Meson Build System' Manufacturer='The Meson Development Team'
Id='%s'
UpgradeCode='%s'
Language='1033' Codepage='1252' Version='%s'>
<Package Id='*' Keywords='Installer' Description="Meson %s installer"
Comments='Meson is a high performance build system' Manufacturer='Meson development team'
InstallerVersion='200' Languages='1033' Compressed='yes' SummaryCodepage='1252'
%s />
<Media Id="1" Cabinet="meson.cab" EmbedCab="yes" />
<Directory Id='TARGETDIR' Name='SourceDir'>
<Directory Id="%s">
<Directory Id="INSTALLDIR" Name="Meson">
'''
xml_footer_templ = '''
</Directory>
</Directory>
</Directory>
<Feature Id="DefaultFeature" Level="1">
%s
</Feature>
<Property Id="WIXUI_INSTALLDIR" Value="INSTALLDIR" />
<UIRef Id="WixUI_InstallDir" />
</Product>
</Wix>
'''
file_templ = '''<File Id='%s' Name='%s' DiskId='1' Source='%s' />
'''
comp_ref_templ = '''<ComponentRef Id="%s" />
'''
path_addition_xml = '''<Environment Id="Environment" Name="PATH" Part="last" System="yes" Action="set" Value="[INSTALLDIR]"/>
'''
def gen_guid():
return str(uuid.uuid4()).upper()
@ -165,31 +121,24 @@ class PackageGenerator:
'Id': 'WixUI_InstallDir',
})
assert(os.path.isdir(self.staging_dir))
comp_ref_xml = ''
nodes = {}
with open(self.main_xml, 'w') as ofile:
for root, dirs, files in os.walk(self.staging_dir):
cur_node = Node(dirs, files)
nodes[root] = cur_node
ofile.write(xml_templ % (self.guid, self.update_guid, self.version, self.version,
self.platform_str, self.progfile_dir))
self.component_num = 0
self.create_xml(nodes, ofile, self.staging_dir, installdir)
feature = ET.SubElement(product, 'Feature', {
'Id': 'DefaultFeature',
'Level': '1',
for root, dirs, files in os.walk(self.staging_dir):
cur_node = Node(dirs, files)
nodes[root] = cur_node
self.component_num = 0
self.create_xml(nodes, self.staging_dir, installdir)
feature = ET.SubElement(product, 'Feature', {
'Id': 'DefaultFeature',
'Level': '1',
})
for i in range(self.component_num):
ET.SubElement(feature, 'ComponentRef', {
'Id': 'ApplicationFiles%d' % i,
})
for i in range(self.component_num):
ET.SubElement(feature, 'ComponentRef', {
'Id': 'ApplicationFiles%d' % i,
})
comp_ref_xml += comp_ref_templ % ('ApplicationFiles%d' % i)
ofile.write(xml_footer_templ % comp_ref_xml)
ET.ElementTree(self.root).write(self.main_xml, encoding='utf-8',xml_declaration=True)
def create_xml(self, nodes, ofile, current_dir, parent_xml_node):
def create_xml(self, nodes, current_dir, parent_xml_node):
cur_node = nodes[current_dir]
if cur_node.files:
comp_xml_node = ET.SubElement(parent_xml_node, 'Component', {
@ -207,9 +156,6 @@ class PackageGenerator:
'Action': 'set',
'Value': '[INSTALLDIR]',
})
ofile.write("<Component Id='ApplicationFiles%d' Guid='%s' %s>\n" % (self.component_num, gen_guid(), self.component_platform))
if self.component_num == 0:
ofile.write(path_addition_xml)
self.component_num += 1
for f in cur_node.files:
file_source = os.path.join(current_dir, f).replace('\\', '\\\\')
@ -219,8 +165,6 @@ class PackageGenerator:
'Name': f,
'Source': os.path.join(current_dir, f),
})
ofile.write(file_templ % (file_id, f, file_source))
ofile.write('</Component>\n')
for dirname in cur_node.dirs:
dir_id = os.path.join(current_dir, dirname).replace('\\', '_').replace('/', '_')
@ -228,11 +172,7 @@ class PackageGenerator:
'Id': dir_id,
'Name': dirname,
})
ofile.write('''<Directory Id="%s" Name="%s">\n''' % (dir_id, dirname))
self.create_xml(nodes, ofile, os.path.join(current_dir, dirname), dir_node)
ofile.write('</Directory>\n')
self.create_xml(nodes, os.path.join(current_dir, dirname), dir_node)
def build_package(self):
wixdir = 'c:\\Program Files\\Wix Toolset v3.11\\bin'

Loading…
Cancel
Save