欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Conan 笔记

程序员文章站 2022-03-22 13:12:44
...

Conan 笔记

起因

根据conan官方的教程,在执行时

conan create . demo/testing

产生了疑问,好像并没有说明’conan create’是干什么的.
于是上网查阅得知:
conan Export命令是构建之后通过export 命令导出模块到本地仓库,可以在本地为其他项目提供依赖.
也就是官方教程中的这两句:
Copies (“export” in Conan terms) the conanfile.py from the user folder into the local cache. Installs the package, forcing it to be built from the sources.
然后我们可以在本地查看到,Hello文件夹已经出现在了本地缓存中Conan 笔记
执行,

$ conan search
Existing package recipes:

Hello/aaa@qq.com/testing

可以看到Hello已经加入了本地仓库

打包项目

感谢https://blog.csdn.net/lyu00002/article/details/86699175
其实这个官方的教程展现了一个打包的基本过程,那么我们来回顾一下打包项目的过程和原理:
每个包装配方包含本地缓存中的五个重要文件夹:

  • export:存储包装配方的文件夹。
  • export_source:exports_sources存储使用recipe 属性复制的代码的文件夹。
  • source:存储源代码构建源代码的文件夹。
  • build:完成源的实际编译的文件夹。每个不同的二进制配置通常会有一个子文件夹
  • package:存储最终包工件的文件夹。每个不同的二进制配置将有一个子文件夹。

该源和建立文件夹,只有当包已经从源代码构建的存在。
Conan 笔记
通过conan export命令或更典型地使用conan create命令“导出”包时,该过程开始。该字段指定的conanfile.py和文件 exports_sources将从用户空间复制到本地缓存。

将export和export_source文件复制到源文件夹,然后source() 执行该方法(如果存在)。请注意,所有二进制包只有一个源文件夹。如果在生成代码时,有不同配置的源代码,则无法使用该source()方法生成,而是需要使用该build()方法生成 。

然后,对于每个不同的设置和选项配置,将为此配置以SHA-1哈希的形式计算包ID。源将被复制到build / hashXXX文件夹,并将build()触发该方法。

之后,package()将调用该方法将构件/ hashXXX 文件夹中的工件复制到package / hashXXX文件夹。

最后,package_info()所有依赖的方法将被调用,聚集这样你就可以产生对消费者构建系统文件,作为conanbuildinfo.cmake的cmake 编译器。此imports功能还会将本地缓存中的工件复制到用户空间(如果已指定)。

简单打包方法

让我们为包装配方创建一个文件夹,并使用conan new命令为我们创建一个模版:

$ mkdir mypkg && cd mypkg
$ conan new Hello/0.1 -t

会给我们生成以下文件

conanfile.py
test_package
  CMakeLists.txt
  conanfile.py
  example.cpp

conanfile.py 中定义了如何打包如何导入源文件。以及项目具体信息。具体conanfile.py里面方法参考:https://docs.conan.io/en/latest/reference/conanfile.html#conanfile-reference

conanfile.py文件内容:

from conans import ConanFile, CMake, tools

class HelloConan(ConanFile):
    name = "Hello"
    version = "0.1"
    license = "<Put the package license here>"
    url = "<Package recipe repository url here, for issues about the package>"
    description = "<Description of Hello here>"
    settings = "os", "compiler", "build_type", "arch"
    options = {"shared": [True, False]}
    default_options = {"shared": False}
    generators = "cmake"

    def source(self):
        self.run("git clone https://github.com/memsharded/hello.git")
        self.run("cd hello && git checkout static_shared")
        # This small hack might be useful to guarantee proper /MT /MD linkage
        # in MSVC if the packaged project doesn't have variables to set it
        # properly
        tools.replace_in_file("hello/CMakeLists.txt", "PROJECT(MyHello)",
                              '''PROJECT(MyHello)
include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
conan_basic_setup()''')

    def build(self):
        cmake = CMake(self)
        cmake.configure(source_folder="hello")
        cmake.build()

        # Explicit way:
        # self.run('cmake %s/hello %s'
        #          % (self.source_folder, cmake.command_line))
        # self.run("cmake --build . %s" % cmake.build_config)

    def package(self):
        self.copy("*.h", dst="include", src="hello")
        self.copy("*hello.lib", dst="lib", keep_path=False)
        self.copy("*.dll", dst="bin", keep_path=False)
        self.copy("*.so", dst="lib", keep_path=False)
        self.copy("*.dylib", dst="lib", keep_path=False)
        self.copy("*.a", dst="lib", keep_path=False)

    def package_info(self):
        self.cpp_info.libs = ["hello"]

build 是你要具体如何编译项目

source source方法表示导入源文件。但是是为git方式来使用的。例子中会去git上下载源文件导入到conan的缓存中

package 打包你的项目。注意python文件中的 copy 函数,里面的dst是拷贝到conan的package下面。并不能随意的指定路径。

test_package 文件夹里面是“包”测试,你可以在example.cpp中写测试,并验证包是否正确创建,你可以在里面写一些测试case测试你的包是否好使。

test_package 具体参考:https://docs.conan.io/en/latest/creating_packages/getting_started.html#creating-the-package-recipe

执行conan create . demo/testing 创建并打包你的包

conan create . demo/testing

在柯南创建命令执行以下操作:

  • 将conanfile.py从用户文件夹复制(以conan术语“导出”)到conan的本地缓存中。
  • 安装包,强制从源构建它。
  • 移动到test_package文件夹并创建临时构建文件夹。
  • 执行conan install …,以安装test_package / conanfile.py的要求 。请注意,它将从源构建“Hello”。
  • 构建并启动示例消费应用程序,分别调用test_package / conanfile.py build()和test()方法。
    使用Conan命令,conan create命令将等效于:
$ conan export . demo/testing
$ conan install Hello/aaa@qq.com/testing --build=Hello
# package is created now, use test to test it
$ conan test test_package Hello/aaa@qq.com/testing

打包项目(扩展)

有些项目并不是第三方开发。是自己开发的。这种就不能通过source导入你的项目。可以通过exports_sources 方法将你的源代码导入到conan的缓存中。

以下是conanfile.py的示例。删除掉source方法。增加exports_sources 表示你的源代码路径。conan在执行conanfile.py时将你的源代码导入到conan的缓存 export_source路径下面。

from conans import ConanFile, CMake

class HelloConan(ConanFile):
    name = "Hello"
    version = "0.1"
    license = "<Put the package license here>"
    url = "<Package recipe repository url here, for issues about the package>"
    description = "<Description of Hello here>"
    settings = "os", "compiler", "build_type", "arch"
    options = {"shared": [True, False]}
    default_options = {"shared": False}
    generators = "cmake"
    exports_sources = "src/*"

    def build(self):
        cmake = CMake(self)
        cmake.configure(source_folder="src")
        cmake.build()
        cmake.install()

        # Explicit way:
        # self.run('cmake "%s/src" %s' % (self.source_folder, cmake.command_line))
        # self.run("cmake --build . %s" % cmake.build_config)

    def package(self):
        pass

    def package_info(self):
        self.cpp_info.libs = ["hello"]
  • 添加了该exports_sources字段,指示柯南将本地src 文件夹中的所有文件复制到包装配方中。

  • 删除了该source()方法,因为不再需要检索外部源。同时你需要注意你的CMakeList文件是否引用了相关依赖库,如果引用你需要加入conanbuildinfo.cmake到你的CMakeList文件。
    include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
    conan_basic_setup()

    打包项目-直接打包编译好的项目
    直接打包项目。不从源代码开始进行编译。
    – 创建一个带有conanfile.py的文件
    conan new gdal/aaa@qq.com/testing
    – 直接打包文件到conan package文件夹下 --force 如果已经有了直接覆盖
    conan export-pkg . gdal/aaa@qq.com/testing -pf=/opt/gpsql --force

相关标签: 项目管理