123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- #!/usr/bin/env python
- import argparse
- import os
- import shutil
- import sys
- import tarfile
- from lib.util import safe_mkdir, scoped_cwd
- SOURCE_ROOT = os.path.abspath(os.path.dirname(os.path.dirname(__file__)))
- DIST_DIR = os.path.join(SOURCE_ROOT, 'dist')
- NODE_DIR = os.path.join(SOURCE_ROOT, 'vendor', 'node')
- OUT_DIR = os.path.join(SOURCE_ROOT, 'out', 'R')
- HEADERS_SUFFIX = [
- '.h',
- '.gypi',
- ]
- HEADERS_DIRS = [
- 'src',
- 'deps/http_parser',
- 'deps/zlib',
- 'deps/uv',
- 'deps/npm',
- 'deps/mdb_v8',
- 'deps/v8/include'
- ]
- HEADERS_FILES = [
- 'common.gypi',
- 'config.gypi',
- ]
- def main():
- args = parse_args()
- safe_mkdir(args.directory)
- node_headers_dir = os.path.join(args.directory,
- 'node-{0}'.format(args.version))
- iojs_headers_dir = os.path.join(args.directory,
- 'iojs-{0}'.format(args.version))
- iojs2_headers_dir = os.path.join(args.directory,
- 'iojs-{0}-headers'.format(args.version))
- copy_headers(node_headers_dir)
- create_header_tarball(args.directory, node_headers_dir)
- copy_headers(iojs_headers_dir)
- create_header_tarball(args.directory, iojs_headers_dir)
- copy_headers(iojs2_headers_dir)
- create_header_tarball(args.directory, iojs2_headers_dir)
- def parse_args():
- parser = argparse.ArgumentParser(description='create node header tarballs')
- parser.add_argument('-v', '--version', help='Specify the version',
- required=True)
- parser.add_argument('-d', '--directory', help='Specify the output directory',
- default=DIST_DIR,
- required=False)
- return parser.parse_args()
- def copy_headers(dist_headers_dir):
- safe_mkdir(dist_headers_dir)
- # Copy standard node headers from node. repository.
- for include_path in HEADERS_DIRS:
- abs_path = os.path.join(NODE_DIR, include_path)
- for dirpath, _, filenames in os.walk(abs_path):
- for filename in filenames:
- extension = os.path.splitext(filename)[1]
- if extension not in HEADERS_SUFFIX:
- continue
- copy_source_file(os.path.join(dirpath, filename), NODE_DIR,
- dist_headers_dir)
- for other_file in HEADERS_FILES:
- copy_source_file(os.path.join(NODE_DIR, other_file), NODE_DIR,
- dist_headers_dir)
- # Copy V8 headers from chromium's repository.
- src = os.path.join(SOURCE_ROOT, 'vendor', 'download', 'libchromiumcontent',
- 'src')
- for dirpath, _, filenames in os.walk(os.path.join(src, 'v8')):
- for filename in filenames:
- extension = os.path.splitext(filename)[1]
- if extension not in HEADERS_SUFFIX:
- continue
- copy_source_file(os.path.join(dirpath, filename), src,
- os.path.join(dist_headers_dir, 'deps'))
- def create_header_tarball(directory, dist_headers_dir):
- target = dist_headers_dir + '.tar.gz'
- with scoped_cwd(directory):
- tarball = tarfile.open(name=target, mode='w:gz')
- tarball.add(os.path.relpath(dist_headers_dir))
- tarball.close()
- def copy_source_file(source, start, destination):
- relative = os.path.relpath(source, start=start)
- final_destination = os.path.join(destination, relative)
- safe_mkdir(os.path.dirname(final_destination))
- shutil.copy2(source, final_destination)
- if __name__ == '__main__':
- sys.exit(main())
|