NuGet是微软开发平台下的包管理软件,使用它你可以非常方便的将一些第三方的库、框架整合进自己的项目中,省去了不少麻烦的配置过程。但是从官方文档上来看,貌似NuGet对C++的支持不是很好,并且在现阶段推荐使用CoApp来简化包的构建。

1. 环境要求

  • NuGet 2.5 及以上(较新版本才加入了对C++包的支持)
  • Windows Vista及以上,PowerShell 3.0(CoApp使用PS来构建C++本地包)
  • CoApp(简化包的构建过程,安装详见官网)

2. 准备材料

  • 静态库及相应发布的头文件
  • 静态库符号数据库(即PDB文件)
  • 文档(可选)

3. 编写AutoPackage脚本

这个脚本是用来指导CoApp构建我们的静态库包的,一般使用.autopkg作为其扩展名。 该文件由多个节点(Node)组成,节点的写法相当于C++中的命名空间。

3.1 nuget节点

这是脚本的父节点,它包含所有用来生成NuGet包的子节点。

nuget{

}

3.2 nuspec子节点

该节点包含要创建包的元数据,我们在这里指定将要生成的包的描述信息,这些信息会被显示在NuGet官网中的包页面下。常用的主要有:

  1. ID
  2. 版本(version)
  3. 标题(title)
  4. 作者(authors)
  5. 所有者(owners)
  6. 许可文件地址(licenseUrl)
  7. 项目地址(projectUrl)
  8. 图标地址(iconUrl)
  9. 概要(summary)
  10. 描述(description)
  11. 标签(tags)

这个节点是nuget的子节点,元数据的具体写法如下(注意每一项元数据后面都要跟一个分号;):

nuspec
{
id = EasyXPlus;
version : 1.0.1;
title: EasyXPlus;
authors: lgxZJ@outlook.com;
projectUrl: "https://github.com/lgxZJ/EasyXPlus";
summary:A simple C++ graphic library for BEGINNERS under windows!; description: "A simple C++ graphic library for BEGINNERS under windows!";
tags: { beta, native, c++ };
}

3.3 files子节点

files节点也是nuget的子节点,用来指定生成包所需要的文件。对于C++静态库来说,我们只需要在files节点中指定三种文件:

1.头文件include : { "headers\*" }; 我们指定相对目录headers下的所有文件为发布的头文件。

2.文档(可选):docs : { "doc\html\* }; 我们指定相对目录doc\html下的所有文件为文档。

3.库文件、PDB文件:对于这些文件我们需要指定目标平台、VS版本和开发模式:

[x86, v140, debug] {
lib: builds\vs2015\libeasy\Debug\libeasyd.lib;
symbols: builds\vs2015\libeasy\Debug\libeasy.pdb;
}
[x64, v140, release] {
...
}

这个数据项格式不同于其他简单的项,不需要在末尾跟分号;

下面是一些VS版本号与对应工具集:

  • VS2015 ---- v140
  • VS2013 ---- v120
  • VS2012 ---- v110
  • VS2010 ---- v100

3.4 targets子节点

我们没有用到这个节点,因此简单的在Defines定义中加上一个值:

targets
{
Defines += HAS_EASYXPLUS;
}

至此,我们的脚本就编写结束了,完整的文件见链接

4. VS2015发布支持

但是CoApp还没有正式的版本支持VS2015,因此我们采用了github上一个workaround,这个节点需要写在nuget节点之前

configurations {
Toolset {
key : "PlatformToolset";
choices: { v140 };
// Explicitly Not including pivot variants: "WindowsKernelModeDriver8.0", "WindowsApplicationForDrivers8.0", "WindowsUserModeDriver8.0" // We're normalizing out the concept of the v140 platform -- Overloading the $(PlatformToolset) variable for additional pivots was a dumb idea.
v140.condition = "( $(PlatformToolset.ToLower().IndexOf('v140')) > -1 Or '$(PlatformToolset.ToLower())' == 'windowskernelmodedriver8.0' Or '$(PlatformToolset.ToLower())' == 'windowsapplicationfordrivers8.0' Or '$(PlatformToolset.ToLower())' == 'windowsusermodedriver8.0' )";
};
}

5. 创建C++静态库包

在PowerShell下运行以下命令构建本地包,本地包默认在脚本所在目录下生成:

Write-NuGetPackage .\EasyXPlus.autopkg

如果运行时PowerShell提示无法加载模块或者无法加载文件,可以试着执行set-executionpolicy remotesigned

使用CoApp创建NuGet C++静态库包的更多相关文章

  1. 创建并使用静态库(ar 命令)

     创建并使用静态库(ar 命令)            archive命令的功能是:创建或改动归档文件或者从归档文件里析取信息.能够简单的理解为一个打包工具,将成员文件依照一定的规则构建到.a文件里, ...

  2. autotools入门笔记(二)——创建和使用静态库、动态库

    带有静态库或者动态库的工程的构建过程与上一节()只包含一个源文件的工程的构建过程是类似的.只是对于复杂的工程,如果包含多个还有源文件的目录时,需要对每个包含源文件的目录执行构建过程,另外创建和使用库文 ...

  3. # 2017-2018-2 20155228 《信息安全系统设计原理》 使用VirtualStudio2008创建和调用静态库和使用VirtualC++6.0创建和调用动态库

    使用virtual c++ 6.0创建和调用动态库 不得不说一下关于环境的问题 只要我打一个响指,一半的安装在win7上的VC6.0都会因为兼容性问题直接崩掉 懒得研究怎么解决兼容性的问题了,直接开一 ...

  4. Linux中创建和使用静态库&动态库

    库本质上来说库是一种可执行代码的二进制形式,可以被操作系统载入内存执行 Linux下库的种类 linux下的库有两种:静态库和共享库(动态库). 二者的不同点在于代码被载入的时刻不同. 静态库的代码在 ...

  5. gcc创建和使用静态库、动态库

    http://www.cnblogs.com/dyllove98/archive/2013/06/25/3155599.html 目录树结构: test/include/hello.h #ifdef ...

  6. Xcode5创建自己的静态库详解

    首先声明: 本人屌丝一枚,如有不对不妥之处,请大牛指正! 1.静态库工程的建立: Xcode New一个新的project,选择IOS下面的Framework&Library,下面有一个Coc ...

  7. codeblocks创建和使用静态库(C语言)

    静态库  (扩展名为 .a 或 .lib) 是包含函数的文件,用于在link阶段整合执行程序,动态链接库(扩展名  .dll)是不在link阶段整合进执行程序中的. DLL文件在执行阶段动态调用 下面 ...

  8. (一〇四)使用Xcode6创建framework动态静态库

    在Xcode6以前,创建framework可以使用iOS-Universal-Framework模板来创建framework,现在苹果已经提供了模板,如下图选择: 使用此模版创建的默认是动态库,方法和 ...

  9. 演练:创建和使用静态库 (C++)

    我们将创建的下一个库类型是静态库 (LIB). 使用静态库是重用代码的一种绝佳方式. 您不必在自己创建的每个程序中重新实现同一例程,而只需对这些例程编写一次,然后从需要该功能的应用程序引用它们即可. ...

随机推荐

  1. Modelsim使用笔记(一个完成工程的仿真)

    这学期在玩Altera的板子,不不, 现在应该叫intel PSG.在QuartusII13.0上老喜欢用modelsim_ae做仿真,小工程用起来也方便,但是我做IIC配置摄像头的时序仿真时,就显得 ...

  2. single number i && ii && iii

    Problem statement Elementary knowledge: There is a popular question when I seeked my job at Beijing: ...

  3. ReactiveCocoa学习总结(1)

    1. 它是什么? 官方解释: [RACSignal] is a push-driven stream with a focus on asynchronous event delivery throu ...

  4. 策略模式(stragegy)

    策略模式(stragegy) 定义了算法族,分别封装起来,让它们之间可以相互替换,此模式让算法独立于使用算法的客户(Head First 设计模式).    策略模式,针对接口编程,而不依赖于具体的实 ...

  5. JDK版本会影响项目部署

    最近在公司里面部署javaweb项目的时候,项目启动的时候报错,我使用了各种方法来寻找答案,将近花了很长的时间.就在今天我终于找到了问题的根源,我开始用的是JDK1.8的版本,换了一个1.7版本的JD ...

  6. git使用命令总结

    直接安装git.exegit -- version 查看当前git版本进入要创建库的文件夹 shift+右键 弹出 powerShell 弹出命令窗口 git init 初始化git管理仓库 出现一个 ...

  7. 浅谈一下web移动端基本

    屏幕尺寸.屏幕分辨率.屏幕像素密度 屏幕尺寸: 指屏幕的对角线的长度,单位是英寸,1英寸=2.54厘米. 常见的屏幕尺寸有2.4.2.8.3.5.3.7.4.2.5.0.5.5.6.0等. 屏幕分辨率 ...

  8. .NET 通过 Autofac 和 DynamicProxy 实现AOP

    什么是AOP?引用百度百科:AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术.实现AOP主要由两 ...

  9. JVM方法调用

    当我们站在JVM实现的角度去看方法调用的时候,我们自然会想到一种分类: 1.编译代码的时候就知道是哪个方法,永远不会产生歧义,例如静态方法,private方法,构造方法,super方法. 2.运行时才 ...

  10. ArrayList源码解析(一)

    源码解析系列主要对Java的源码进行详细的说明,由于水平有限,难免出现错误或描述不准确的地方,还请大家指出. 1.位置 ArrayList位于java.util包中. package java.uti ...