|  | #!/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. | 
|  |  | 
|  | # Script to install the Chrome OS fonts on Linux. | 
|  | # This script can be run manually (as root), but is also run as part | 
|  | # install-build-deps.sh. | 
|  |  | 
|  | import os | 
|  | import shutil | 
|  | import subprocess | 
|  | import sys | 
|  |  | 
|  | URL_TEMPLATE = ('https://commondatastorage.googleapis.com/chromeos-localmirror/' | 
|  | 'distfiles/%(name)s-%(version)s.tar.bz2') | 
|  |  | 
|  | # Taken from the media-fonts/<name> ebuilds in chromiumos-overlay. | 
|  | # noto-cjk used to be here, but is removed because fc-cache takes too long | 
|  | # regenerating the fontconfig cache (See crbug.com/697954.) | 
|  | # TODO(jshin): Add it back when the above issue can be avoided. | 
|  | SOURCES = [ | 
|  | { | 
|  | 'name': 'notofonts', | 
|  | 'version': '20161129' | 
|  | }, { | 
|  | 'name': 'robotofonts', | 
|  | 'version': '2.132' | 
|  | } | 
|  | ] | 
|  |  | 
|  | URLS = sorted([URL_TEMPLATE % d for d in SOURCES]) | 
|  | FONTS_DIR = '/usr/local/share/fonts' | 
|  |  | 
|  | def main(args): | 
|  | if not sys.platform.startswith('linux'): | 
|  | print "Error: %s must be run on Linux." % __file__ | 
|  | return 1 | 
|  |  | 
|  | if os.getuid() != 0: | 
|  | print "Error: %s must be run as root." % __file__ | 
|  | return 1 | 
|  |  | 
|  | if not os.path.isdir(FONTS_DIR): | 
|  | print "Error: Destination directory does not exist: %s" % FONTS_DIR | 
|  | return 1 | 
|  |  | 
|  | dest_dir = os.path.join(FONTS_DIR, 'chromeos') | 
|  |  | 
|  | stamp = os.path.join(dest_dir, ".stamp02") | 
|  | if os.path.exists(stamp): | 
|  | with open(stamp) as s: | 
|  | if s.read() == '\n'.join(URLS): | 
|  | print "Chrome OS fonts already up to date in %s." % dest_dir | 
|  | return 0 | 
|  |  | 
|  | if os.path.isdir(dest_dir): | 
|  | shutil.rmtree(dest_dir) | 
|  | os.mkdir(dest_dir) | 
|  | os.chmod(dest_dir, 0755) | 
|  |  | 
|  | print "Installing Chrome OS fonts to %s." % dest_dir | 
|  | for url in URLS: | 
|  | tarball = os.path.join(dest_dir, os.path.basename(url)) | 
|  | subprocess.check_call(['curl', '-L', url, '-o', tarball]) | 
|  | subprocess.check_call(['tar', '--no-same-owner', '--no-same-permissions', | 
|  | '-xf', tarball, '-C', dest_dir]) | 
|  | os.remove(tarball) | 
|  |  | 
|  | readme = os.path.join(dest_dir, "README") | 
|  | with open(readme, 'w') as s: | 
|  | s.write("This directory and its contents are auto-generated.\n") | 
|  | s.write("It may be deleted and recreated. Do not modify.\n") | 
|  | s.write("Script: %s\n" % __file__) | 
|  |  | 
|  | with open(stamp, 'w') as s: | 
|  | s.write('\n'.join(URLS)) | 
|  |  | 
|  | for base, dirs, files in os.walk(dest_dir): | 
|  | for dir in dirs: | 
|  | os.chmod(os.path.join(base, dir), 0755) | 
|  | for file in files: | 
|  | os.chmod(os.path.join(base, file), 0644) | 
|  |  | 
|  | print """\ | 
|  |  | 
|  | Chrome OS font rendering settings are specified using Fontconfig. If your | 
|  | system's configuration doesn't match Chrome OS's (which vary for different | 
|  | devices), fonts may be rendered with different subpixel rendering, subpixel | 
|  | positioning, or hinting settings. This may affect font metrics. | 
|  |  | 
|  | Chrome OS's settings are stored in the media-libs/fontconfig package, which is | 
|  | at src/third_party/chromiumos-overlay/media-libs/fontconfig in a Chrome OS | 
|  | checkout. You can configure your system to match Chrome OS's defaults by | 
|  | creating or editing a ~/.fonts.conf file: | 
|  |  | 
|  | <?xml version="1.0"?> | 
|  | <!DOCTYPE fontconfig SYSTEM "fonts.dtd"> | 
|  | <fontconfig> | 
|  | <match target="font"> | 
|  | <edit name="antialias" mode="assign"><bool>true</bool></edit> | 
|  | <edit name="autohint" mode="assign"><bool>true</bool></edit> | 
|  | <edit name="hinting" mode="assign"><bool>true</bool></edit> | 
|  | <edit name="hintstyle" mode="assign"><const>hintslight</const></edit> | 
|  | <edit name="rgba" mode="assign"><const>rgb</const></edit> | 
|  | </match> | 
|  | </fontconfig> | 
|  |  | 
|  | To load additional per-font configs (and assuming you have Chrome OS checked | 
|  | out), add the following immediately before the "</fontconfig>" line: | 
|  |  | 
|  | <include ignore_missing="yes">/path/to/src/third_party/chromiumos-overlay/media-libs/fontconfig/files/local.conf</include> | 
|  | """ | 
|  |  | 
|  | return 0 | 
|  |  | 
|  | if __name__ == '__main__': | 
|  | sys.exit(main(sys.argv[1:])) |