2015-11-25 05:35:17 +08:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
2015-11-25 05:35:32 +08:00
|
|
|
"""
|
|
|
|
Shared functionality used by `client` and `server` when generating or preparing
|
|
|
|
to generate SWIG on the local machine.
|
|
|
|
"""
|
|
|
|
|
2015-11-25 05:35:17 +08:00
|
|
|
# Future imports
|
|
|
|
from __future__ import absolute_import
|
|
|
|
from __future__ import print_function
|
|
|
|
|
|
|
|
# Python modules
|
|
|
|
import argparse
|
|
|
|
import imp
|
2015-11-25 05:35:32 +08:00
|
|
|
import io
|
2015-11-25 05:35:17 +08:00
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
import sys
|
2015-11-25 05:35:50 +08:00
|
|
|
import tempfile
|
2015-11-25 05:35:32 +08:00
|
|
|
import zipfile
|
2015-11-25 05:35:17 +08:00
|
|
|
|
|
|
|
# LLDB modules
|
|
|
|
import use_lldb_suite
|
|
|
|
|
2015-12-01 06:31:13 +08:00
|
|
|
# Package imports
|
|
|
|
from lldbsuite.support import fs
|
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2015-12-01 06:31:13 +08:00
|
|
|
class LocalConfig(object):
|
2015-11-25 05:35:50 +08:00
|
|
|
src_root = None
|
|
|
|
target_dir = None
|
|
|
|
languages = None
|
|
|
|
swig_executable = None
|
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2015-12-01 06:31:13 +08:00
|
|
|
def pack_archive(bytes_io, src_root, filters):
|
2015-11-25 05:35:32 +08:00
|
|
|
logging.info("Creating input file package...")
|
|
|
|
zip_file = None
|
|
|
|
try:
|
|
|
|
# It's possible that a custom-built interpreter will not have the
|
|
|
|
# standard zlib module. If so, we can only store, not compress. By
|
|
|
|
# try to compress since we usually have a standard Python distribution.
|
2015-12-01 06:31:13 +08:00
|
|
|
zip_file = zipfile.ZipFile(bytes_io, mode='w',
|
2015-11-25 05:35:32 +08:00
|
|
|
compression=zipfile.ZIP_DEFLATED)
|
|
|
|
except RuntimeError:
|
2015-12-01 06:31:13 +08:00
|
|
|
zip_file = zipfile.ZipFile(bytes_io, mode='w',
|
2015-11-25 05:35:32 +08:00
|
|
|
compression=zipfile.ZIP_STORED)
|
2015-12-01 06:31:24 +08:00
|
|
|
archive_entries = []
|
|
|
|
if filters is not None:
|
|
|
|
def filter_func(t):
|
|
|
|
subfolder = t[0]
|
|
|
|
ext = t[1]
|
|
|
|
full_path = os.path.normpath(os.path.join(src_root, subfolder))
|
|
|
|
candidates = [os.path.normpath(os.path.join(full_path, f))
|
|
|
|
for f in os.listdir(full_path)]
|
|
|
|
actual = filter(
|
2016-09-07 04:57:50 +08:00
|
|
|
lambda f: os.path.isfile(f) and os.path.splitext(f)[1] == ext,
|
2015-12-01 06:31:24 +08:00
|
|
|
candidates)
|
2016-09-07 04:57:50 +08:00
|
|
|
return (subfolder, map(lambda f: os.path.basename(f), actual))
|
2015-12-01 06:31:24 +08:00
|
|
|
archive_entries = map(filter_func, filters)
|
|
|
|
else:
|
|
|
|
for (root, dirs, files) in os.walk(src_root):
|
|
|
|
logging.debug("Adding files {} from directory {} to output package"
|
|
|
|
.format(files, root))
|
|
|
|
if len(files) > 0:
|
|
|
|
rel_root = os.path.relpath(root, src_root)
|
|
|
|
archive_entries.append((rel_root, files))
|
|
|
|
|
|
|
|
archive_entries = list(archive_entries)
|
2015-11-25 05:35:32 +08:00
|
|
|
for entry in archive_entries:
|
|
|
|
subfolder = entry[0]
|
2015-12-01 06:31:24 +08:00
|
|
|
files = list(entry[1])
|
2015-11-25 05:35:32 +08:00
|
|
|
for file in files:
|
2015-12-01 06:31:24 +08:00
|
|
|
rel_path = os.path.normpath(os.path.join(subfolder, file))
|
|
|
|
full_path = os.path.join(src_root, rel_path)
|
|
|
|
logging.info("{} -> {}".format(full_path, rel_path))
|
|
|
|
zip_file.write(full_path, rel_path)
|
2015-11-25 05:35:50 +08:00
|
|
|
|
2015-12-01 06:31:13 +08:00
|
|
|
return zip_file
|
2015-11-25 05:35:32 +08:00
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2015-12-01 06:31:24 +08:00
|
|
|
def unpack_archive(folder, archive_bytes):
|
2015-11-25 05:35:50 +08:00
|
|
|
zip_data = io.BytesIO(archive_bytes)
|
|
|
|
logging.debug("Opening zip archive...")
|
|
|
|
zip_file = zipfile.ZipFile(zip_data, mode='r')
|
2015-12-01 06:31:24 +08:00
|
|
|
zip_file.extractall(folder)
|
2015-11-25 05:35:50 +08:00
|
|
|
zip_file.close()
|
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2015-11-25 05:35:17 +08:00
|
|
|
def generate(options):
|
|
|
|
include_folder = os.path.join(options.src_root, "include")
|
|
|
|
in_file = os.path.join(options.src_root, "scripts", "lldb.swig")
|
|
|
|
include_folder = os.path.normcase(include_folder)
|
|
|
|
|
|
|
|
for lang in options.languages:
|
|
|
|
lang = lang.lower()
|
|
|
|
out_dir = os.path.join(options.target_dir, lang.title())
|
|
|
|
if not os.path.exists(out_dir):
|
|
|
|
os.makedirs(out_dir)
|
2015-12-01 06:31:24 +08:00
|
|
|
out_file = os.path.join(out_dir, "LLDBWrap{}.cpp".format(lang.title()))
|
2015-11-25 05:35:17 +08:00
|
|
|
swig_command = [
|
|
|
|
options.swig_executable,
|
|
|
|
"-c++",
|
|
|
|
]
|
|
|
|
swig_command.append("-" + lang)
|
|
|
|
if lang == "python":
|
|
|
|
swig_command.append("-threads")
|
|
|
|
|
|
|
|
swig_command.extend([
|
|
|
|
"-I" + include_folder,
|
|
|
|
"-D__STDC_LIMIT_MACROS",
|
|
|
|
"-D__STDC_CONSTANT_MACROS",
|
|
|
|
"-outdir", out_dir,
|
|
|
|
"-o", out_file,
|
|
|
|
in_file
|
|
|
|
])
|
|
|
|
|
2015-11-25 05:35:32 +08:00
|
|
|
logging.info("generating swig {} bindings into {}"
|
|
|
|
.format(lang, out_dir))
|
2015-11-25 05:35:17 +08:00
|
|
|
logging.debug("swig command line: {}".format(swig_command))
|
|
|
|
try:
|
|
|
|
# Execute swig
|
|
|
|
swig_output = subprocess.check_output(
|
|
|
|
swig_command, stderr=subprocess.STDOUT, universal_newlines=True)
|
|
|
|
|
|
|
|
logging.info("swig generation succeeded")
|
|
|
|
if swig_output is not None and len(swig_output) > 0:
|
|
|
|
logging.info("swig output: %s", swig_output)
|
2015-12-01 06:31:24 +08:00
|
|
|
return (0, swig_output)
|
2015-11-25 05:35:17 +08:00
|
|
|
except subprocess.CalledProcessError as e:
|
2015-11-25 05:35:32 +08:00
|
|
|
logging.error("An error occurred executing swig. returncode={}"
|
|
|
|
.format(e.returncode))
|
2015-11-25 05:35:17 +08:00
|
|
|
logging.error(e.output)
|
2016-09-07 04:57:50 +08:00
|
|
|
return (e.returncode, e.output)
|