mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-06 00:10:25 +00:00
b03ee925ac
In a nonpackaged build, we have the following manifests: * chrome.manifest is just a series of manifest directives for all the other manifests, generated in rules.mk using buildlist.py ** components/interfaces.manifest is also generated in rules.mk using buildlist.py ** components/components.manifest contains only the *binary* components. JS components each have their own manifest which is installed to dist/bin/components ** Each chrome/jarfile.jar has a matching chrome/jarfile.manifest, and JarMaker.py inserts this filename into the root chrome.manifest by importing buildlist.py In a packaged build, we end up with the following manifests: * chrome.manifest lists the four manifests below ** components/interfaces.manifest ** components/components.manifest ** chrome/nonlocalized.manifest ** chrome/localized.manifest In the future it should be possible to integrate the three non-localized manifests directly into the root chrome.manifest for increased performance, but this is slightly tricky because it involves rewriting some manifest instructions which may include relative JAR URIs. That is left for a future followup. When we repackage a l10n build, we only have to replace chrome/localized.manifest.
21 lines
519 B
Python
21 lines
519 B
Python
import sys, os
|
|
|
|
outmanifest = sys.argv[1]
|
|
manifestdirs = sys.argv[2:]
|
|
|
|
outfd = open(outmanifest, 'w')
|
|
|
|
for manifestdir in manifestdirs:
|
|
if not os.path.isdir(manifestdir):
|
|
print >>sys.stderr, "Warning: trying to link manifests in missing directory '%s'" % manifestdir
|
|
continue
|
|
|
|
for name in os.listdir(manifestdir):
|
|
infd = open(os.path.join(manifestdir, name))
|
|
print >>outfd, "# %s" % name
|
|
outfd.write(infd.read())
|
|
print >>outfd
|
|
infd.close()
|
|
|
|
outfd.close()
|