在setup.py 中使用cmake

本文介绍如何在setup.py 中使用cmake.

  • 适用场景: 采用c/c++ 为python添加扩展模版

项目组织结构

  • top-level CMakeLists.txt 与 setup.py 放在同级目录下
CMakeLists.txt
setup.py
...

setup.py 文件内容

import os
import re
import sys
import platform
import subprocess
import pathlib

from setuptools import setup, Extension
from setuptools.command.build_ext import build_ext
from distutils.version import LooseVersion


class CMakeExtension(Extension):
    """
    自定义了 Extension 类,忽略原来的 sources、libraries 等参数,交给 CMake 来处理这些事情
    """
    def __init__(self, name, sourcedir=''):
        Extension.__init__(self, name, sources=[])
        self.sourcedir = os.path.abspath(sourcedir)


class CMakeBuild(build_ext):
    """
    自定义了 build_ext 类,对 CMakeExtension 的实例,调用 CMake 和 Make 命令来编译它们
    """
    def run(self):
        for ext in self.extensions:
            if isinstance(ext, CMakeExtension):
                self.build_cmake(ext)
        super().run()

    def build_cmake(self, ext):
        cwd = pathlib.Path().absolute()

        build_temp = f"{pathlib.Path(self.build_temp)}/{ext.name}"
        os.makedirs(build_temp, exist_ok=True)
        extdir = pathlib.Path(self.get_ext_fullpath(ext.name))
        extdir.mkdir(parents=True, exist_ok=True)

        config = "Debug" if self.debug else "Release"
        cmake_args = [
            "-DCMAKE_LIBRARY_OUTPUT_DIRECTORY=" + str(extdir.parent.absolute()),
            "-DCMAKE_BUILD_TYPE=" + config
        ]

        build_args = [
            "--config", config,
            "--", "-j12"
        ]

        os.chdir(build_temp)
        self.spawn(["cmake", f"{str(cwd)}/{ext.name}"] + cmake_args)
        if not self.dry_run:
            self.spawn(["cmake", "--build", "."] + build_args)
        os.chdir(str(cwd))

setup(
    name='xxx',
    version='0.0.1',
    author='xxx',
    author_email='xxx',
    description='xxx',
    long_description='',
    ext_modules=[CMakeExtension('.')],
    cmdclass=dict(build_ext=CMakeBuild),
    zip_safe=False,
)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
是的,从你提供的文件列表来看,并没有 `setup.py` 文件。这可能是因为你下载的是 TraX 库的源代码,而不是 TraX 库的安装包。 如果你想要使用源代码编译安装 TraX 库,可以按照以下步骤进行: 1. 安装 CMake 工具。CMake 是一个跨平台的构建工具,可以帮助你生成平台相关的构建文件(如 Makefile 或 Visual Studio 项目文件)。你可以在 CMake 官网上下载最新版本的 CMake 工具,并按照官方文档进行安装。 2. 进入 TraX 库的源代码目录,并创建一个新目录作为构建目录。例如: ``` cd path/to/trax mkdir build cd build ``` 这里 `path/to/trax` 是 TraX 库源代码所在的目录路径。 3. 在构建目录执行以下命令,生成平台相关的构建文件: ``` cmake .. ``` 如果你想要指定安装目录,可以使用 `-DCMAKE_INSTALL_PREFIX` 参数。例如: ``` cmake .. -DCMAKE_INSTALL_PREFIX=/path/to/install ``` 这里 `/path/to/install` 是你想要安装 TraX 库的路径。 4. 使用生成的构建文件进行编译。例如,在 Linux/Mac 系统上,可以使用 `make` 命令: ``` make ``` 在 Windows 系统上,可以使用 Visual Studio 或者 MinGW 工具进行编译。 5. 安装 TraX 库。在构建目录执行以下命令: ``` make install ``` 如果你之前指定了安装目录,那么安装命令应该为: ``` make install DESTDIR=/path/to/install ``` 这里 `/path/to/install` 是你之前指定的安装目录。 安装完成后,你就可以在 Python 使用 TraX 库了。你可以在 Python 执行以下代码进行验证: ``` import trax print(trax.__version__) ``` 该代码会输出 TraX 库的版本号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值