def from_build_manifest(cls, build_manifest, src_node): meta = PackageMetadata.from_build_manifest(build_manifest) executables = build_manifest.executables file_sections = build_manifest.resolve_paths(src_node) sources = list([n.abspath() for n in iter_source_files(file_sections)]) ret = cls(meta, executables, sources) ret.build_manifest = build_manifest return ret
def from_build_manifest(cls, build_manifest, src_node): meta = PackageMetadata.from_build_manifest(build_manifest) executables = build_manifest.executables file_sections = build_manifest.resolve_paths(src_node) sources = list([n.abspath() for n in iter_source_files(file_sections)]) ret = cls(meta, executables, sources) ret.build_manifest = build_manifest return ret
def build_egg(build_manifest, build_node, source_root, output_dir=None, output_file=None): meta = PackageMetadata.from_build_manifest(build_manifest) egg_info = EggInfo.from_build_manifest(build_manifest, build_node) # FIXME: fix egg name if output_dir is None: if output_file is None: egg = egg_filename(os.path.join("dist", meta.fullname)) else: egg = os.path.join("dist", output_file) else: if output_file is None: egg = egg_filename(os.path.join(output_dir, meta.fullname)) else: egg = os.path.join(output_dir, output_file) bento.utils.path.ensure_dir(egg) egg_scheme = { "prefix": source_root.abspath(), "eprefix": source_root.abspath(), "sitedir": source_root.abspath() } zid = compat.ZipFile(egg, "w", compat.ZIP_DEFLATED) try: for filename, cnt in egg_info.iter_meta(build_node): zid.writestr(os.path.join("EGG-INFO", filename), cnt) for kind, source, target in build_manifest.iter_built_files( source_root, egg_scheme): if not kind in ["executables"]: zid.write(source.abspath(), target.path_from(source_root)) if kind == "pythonfiles": try: bytecode = bcompile(source.abspath()) except PyCompileError: e = extract_exception() warnings.warn("Error byte-compiling %r" % source.abspath()) else: zid.writestr("%sc" % target.path_from(source_root), bcompile(source.abspath())) finally: zid.close() return
def create_wininst(build_manifest, src_root_node, build_node, egg_info=None, wininst=None, output_dir=None): meta = PackageMetadata.from_build_manifest(build_manifest) if egg_info is None: egg_info = EggInfo.from_build_manifest(build_manifest, build_node) # XXX: do this correctly, maybe use same as distutils ? if wininst is None: wininst = os.path.join(output_dir, wininst_filename(meta)) else: wininst = os.path.join(output_dir, wininst) bento.utils.path.ensure_dir(wininst) egg_info_dir = os.path.join("PURELIB", egg_info_dirname(meta.fullname)) fid, arcname = tempfile.mkstemp(prefix="zip") zid = compat.ZipFile(arcname, "w", compat.ZIP_DEFLATED) try: for filename, cnt in egg_info.iter_meta(build_node): zid.writestr(os.path.join(egg_info_dir, filename), cnt) wininst_paths = compat.defaultdict(lambda: r"DATA\share\$pkgname") wininst_paths.update({ "bindir": "SCRIPTS", "sitedir": "PURELIB", "gendatadir": "$sitedir" }) d = {} for k in build_manifest._path_variables: d[k] = wininst_paths[k] build_manifest.update_paths(d) file_sections = build_manifest.resolve_paths(src_root_node) def write_content(source, target, kind): zid.write(source.abspath(), target.abspath()) for kind, source, target in iter_files(file_sections): write_content(source, target, kind) finally: zid.close() os.close(fid) create_exe(build_manifest, arcname, wininst)
def get_inidata(build_manifest): # Return data describing the installation. meta = PackageMetadata.from_build_manifest(build_manifest) # Write the [metadata] section. lines = [] lines.append("[metadata]") # 'info' will be displayed in the installer's dialog box, # describing the items to be installed. info = meta.description + '\n' # Escape newline characters def escape(s): return s.replace("\n", "\\n") for name in ["author", "author_email", "summary", "maintainer", "maintainer_email", "name", "url", "version"]: data = getattr(meta, name) if name == "summary": name = "description" if data: info = info + ("\n %s: %s" % \ (name.capitalize(), escape(data))) lines.append("%s=%s" % (name, escape(data))) # The [setup] section contains entries controlling # the installer runtime. lines.append("\n[Setup]") # FIXME: handle install scripts #if self.install_script: # lines.append("install_script=%s" % self.install_script) lines.append("info=%s" % escape(info)) # FIXME: handle this correctly lines.append("target_compile=1") lines.append("target_optimize=1") #if self.target_version: # lines.append("target_version=%s" % self.target_version) #if self.user_access_control: # lines.append("user_access_control=%s" % self.user_access_control) title = meta.fullname lines.append("title=%s" % escape(title)) build_info = "Built %s with bento-%s" % \ (time.ctime(time.time()), bento.__version__) lines.append("build_info=%s" % build_info) return "\n".join(lines)
def build_egg(build_manifest, build_node, source_root, output_dir=None, output_file=None): meta = PackageMetadata.from_build_manifest(build_manifest) egg_info = EggInfo.from_build_manifest(build_manifest, build_node) # FIXME: fix egg name if output_dir is None: if output_file is None: egg = egg_filename(os.path.join("dist", meta.fullname)) else: egg = os.path.join("dist", output_file) else: if output_file is None: egg = egg_filename(os.path.join(output_dir, meta.fullname)) else: egg = os.path.join(output_dir, output_file) bento.utils.path.ensure_dir(egg) egg_scheme = {"prefix": source_root.abspath(), "eprefix": source_root.abspath(), "sitedir": source_root.abspath()} zid = compat.ZipFile(egg, "w", compat.ZIP_DEFLATED) try: for filename, cnt in egg_info.iter_meta(build_node): zid.writestr(os.path.join("EGG-INFO", filename), cnt) for kind, source, target in build_manifest.iter_built_files(source_root, egg_scheme): if not kind in ["executables"]: zid.write(source.abspath(), target.path_from(source_root)) if kind == "pythonfiles": try: bytecode = bcompile(source.abspath()) except PyCompileError: e = extract_exception() warnings.warn("Error byte-compiling %r" % source.abspath()) else: zid.writestr("%sc" % target.path_from(source_root), bcompile(source.abspath())) finally: zid.close() return
def create_wininst(build_manifest, src_root_node, build_node, egg_info=None, wininst=None, output_dir=None): meta = PackageMetadata.from_build_manifest(build_manifest) if egg_info is None: egg_info = EggInfo.from_build_manifest(build_manifest, build_node) # XXX: do this correctly, maybe use same as distutils ? if wininst is None: wininst = os.path.join(output_dir, wininst_filename(meta)) else: wininst = os.path.join(output_dir, wininst) bento.utils.path.ensure_dir(wininst) egg_info_dir = os.path.join("PURELIB", egg_info_dirname(meta.fullname)) fid, arcname = tempfile.mkstemp(prefix="zip") zid = compat.ZipFile(arcname, "w", compat.ZIP_DEFLATED) try: for filename, cnt in egg_info.iter_meta(build_node): zid.writestr(os.path.join(egg_info_dir, filename), cnt) wininst_paths = compat.defaultdict(lambda: r"DATA\share\$pkgname") wininst_paths.update({"bindir": "SCRIPTS", "sitedir": "PURELIB", "gendatadir": "$sitedir"}) d = {} for k in build_manifest._path_variables: d[k] = wininst_paths[k] build_manifest.update_paths(d) file_sections = build_manifest.resolve_paths(src_root_node) def write_content(source, target, kind): zid.write(source.abspath(), target.abspath()) for kind, source, target in iter_files(file_sections): write_content(source, target, kind) finally: zid.close() os.close(fid) create_exe(build_manifest, arcname, wininst)