def _package(self, conanfile, pref, package_layout, conanfile_path, build_folder, package_folder): # FIXME: Is weak to assign here the recipe_hash manifest = package_layout.recipe_manifest() conanfile.info.recipe_hash = manifest.summary_hash # Creating ***info.txt files save(os.path.join(build_folder, CONANINFO), conanfile.info.dumps()) self._output.info("Generated %s" % CONANINFO) save(os.path.join(build_folder, BUILD_INFO), TXTGenerator(conanfile).content) self._output.info("Generated %s" % BUILD_INFO) package_id = pref.id # Do the actual copy, call the conanfile.package() method with get_env_context_manager(conanfile): # Could be source or build depends no_copy_source source_folder = conanfile.source_folder install_folder = build_folder # While installing, the infos goes to build folder prev = run_package_method(conanfile, package_id, source_folder, build_folder, package_folder, install_folder, self._hook_manager, conanfile_path, pref.ref) update_package_metadata(prev, package_layout, package_id, pref.ref.revision) if get_env("CONAN_READ_ONLY_CACHE", False): make_read_only(package_folder) # FIXME: Conan 2.0 Clear the registry entry (package ref) return prev
def _package(self, conanfile, pref, package_layout, conanfile_path): # FIXME: Is weak to assign here the recipe_hash manifest = package_layout.recipe_manifest() conanfile.info.recipe_hash = manifest.summary_hash # Creating ***info.txt files save(os.path.join(conanfile.folders.base_build, CONANINFO), conanfile.info.dumps()) self._output.info("Generated %s" % CONANINFO) save(os.path.join(conanfile.folders.base_build, BUILD_INFO), TXTGenerator(conanfile).content) self._output.info("Generated %s" % BUILD_INFO) package_id = pref.id # Do the actual copy, call the conanfile.package() method # While installing, the infos goes to build folder conanfile.folders.set_base_install(conanfile.folders.base_build) prev = run_package_method(conanfile, package_id, self._hook_manager, conanfile_path, pref.ref) update_package_metadata(prev, package_layout, package_id, pref.ref.revision) if get_env("CONAN_READ_ONLY_CACHE", False): make_read_only(conanfile.folders.base_package) # FIXME: Conan 2.0 Clear the registry entry (package ref) return prev
def export_pkg(app, recorder, full_ref, source_folder, build_folder, package_folder, install_folder, graph_info, force, remotes): ref = full_ref.copy_clear_rev() cache, output, hook_manager = app.cache, app.out, app.hook_manager graph_manager = app.graph_manager conan_file_path = cache.package_layout(ref).conanfile() if not os.path.exists(conan_file_path): raise ConanException("Package recipe '%s' does not exist" % str(ref)) # The graph has to be loaded with build_mode=[ref.name], so that node is not tried # to be downloaded from remotes deps_graph = graph_manager.load_graph(ref, None, graph_info=graph_info, build_mode=[ref.name], check_updates=False, update=False, remotes=remotes, recorder=recorder, apply_build_requires=False) # this is a bit tricky, but works. The root (virtual), has only 1 neighbor, # which is the exported pkg nodes = deps_graph.root.neighbors() conanfile = nodes[0].conanfile from conans.client.conan_api import existing_info_files if install_folder and existing_info_files(install_folder): load_deps_info(install_folder, conanfile, required=True) package_id = nodes[0].package_id output.info("Packaging to %s" % package_id) pref = PackageReference(ref, package_id) layout = cache.package_layout(ref, short_paths=conanfile.short_paths) dest_package_folder = layout.package(pref) if os.path.exists(dest_package_folder): if force: rmdir(dest_package_folder) else: raise ConanException("Package already exists. Please use --force, -f to " "overwrite it") recipe_hash = layout.recipe_manifest().summary_hash conanfile.info.recipe_hash = recipe_hash conanfile.develop = True if package_folder: prev = packager.export_pkg(conanfile, package_id, package_folder, dest_package_folder, hook_manager, conan_file_path, ref) else: with get_env_context_manager(conanfile): prev = packager.run_package_method(conanfile, package_id, source_folder, build_folder, dest_package_folder, install_folder, hook_manager, conan_file_path, ref, local=True) packager.update_package_metadata(prev, layout, package_id, full_ref.revision) pref = PackageReference(pref.ref, pref.id, prev) if graph_info.graph_lock: # after the package has been created we need to update the node PREV nodes[0].prev = pref.revision graph_info.graph_lock.update_check_graph(deps_graph, output) recorder.package_exported(pref)
def export_pkg(app, recorder, full_ref, source_folder, build_folder, package_folder, install_folder, graph_info, force, remotes): ref = full_ref.copy_clear_rev() cache, output, hook_manager = app.cache, app.out, app.hook_manager graph_manager = app.graph_manager conan_file_path = cache.package_layout(ref).conanfile() if not os.path.exists(conan_file_path): raise ConanException("Package recipe '%s' does not exist" % str(ref)) # The graph has to be loaded with build_mode=[ref.name], so that node is not tried # to be downloaded from remotes # passing here the create_reference=ref argument is useful so the recipe is in "develop", # because the "package()" method is in develop=True already deps_graph = graph_manager.load_graph(ref, ref, graph_info=graph_info, build_mode=[ref.name], check_updates=False, update=False, remotes=remotes, recorder=recorder, apply_build_requires=False) # this is a bit tricky, but works. The root (virtual), has only 1 neighbor, # which is the exported pkg nodes = deps_graph.root.neighbors() pkg_node = nodes[0] conanfile = pkg_node.conanfile def _init_conanfile_infos(): node_order = [ n for n in pkg_node.public_closure if n.binary != BINARY_SKIP ] subtree_libnames = [node.ref.name for node in node_order] add_env_conaninfo(conanfile, subtree_libnames) _init_conanfile_infos() from conans.client.conan_api import existing_info_files if install_folder and existing_info_files(install_folder): load_deps_info(install_folder, conanfile, required=True) package_id = pkg_node.package_id output.info("Packaging to %s" % package_id) pref = PackageReference(ref, package_id) layout = cache.package_layout(ref, short_paths=conanfile.short_paths) if layout.package_id_exists(package_id) and not force: raise ConanException( "Package already exists. Please use --force, -f to overwrite it") layout.package_remove(pref) dest_package_folder = layout.package(pref) recipe_hash = layout.recipe_manifest().summary_hash conanfile.info.recipe_hash = recipe_hash conanfile.develop = True with layout.set_dirty_context_manager(pref): if package_folder: prev = packager.export_pkg(conanfile, package_id, package_folder, dest_package_folder, hook_manager, conan_file_path, ref) else: prev = run_package_method(conanfile, package_id, source_folder, build_folder, dest_package_folder, install_folder, hook_manager, conan_file_path, ref) packager.update_package_metadata(prev, layout, package_id, full_ref.revision) pref = PackageReference(pref.ref, pref.id, prev) if pkg_node.graph_lock_node: # after the package has been created we need to update the node PREV pkg_node.prev = pref.revision pkg_node.graph_lock_node.prev = pref.revision recorder.package_exported(pref)