diff options
author | Arseny Kapoulkine <arseny.kapoulkine@gmail.com> | 2017-06-18 23:41:12 -0700 |
---|---|---|
committer | Arseny Kapoulkine <arseny.kapoulkine@gmail.com> | 2017-06-20 21:11:35 -0700 |
commit | a7c4070df74e4d62cc8031ae5de9f892fe914bfc (patch) | |
tree | 7d01f56ff91ada2103e5da5572a91ea3396440e3 /scripts/nuget | |
parent | 208e2cf0432a0f2865a225a9dc51917191c6cd04 (diff) |
scripts: Switch to manual NuGet package with both CRT linkages
We'd like to build pugixml with both static & dynamic CRT and put it
all in one NuGet package.
CoApp sort of allows us to do this via dynamic/static pivots, but it
does not let us customize the names of the pivots and additionally has
some bugs with the project setup. Their project modifications are also
much more complicated - really, at this point we should do this
ourselves.
Create a simple native NuGet package with Linkage setting that picks the
right library, and package all libraries appropriately. Note that we use
the unified path syntax to make it simple to just get the right .lib
file from the toolset/platform/configuration/linkage combo.
Diffstat (limited to 'scripts/nuget')
-rw-r--r-- | scripts/nuget/build/native/pugixml-propertiesui.xml | 15 | ||||
-rw-r--r-- | scripts/nuget/build/native/pugixml.targets | 27 | ||||
-rw-r--r-- | scripts/nuget/pugixml.nuspec | 20 |
3 files changed, 62 insertions, 0 deletions
diff --git a/scripts/nuget/build/native/pugixml-propertiesui.xml b/scripts/nuget/build/native/pugixml-propertiesui.xml new file mode 100644 index 0000000..b2e02bb --- /dev/null +++ b/scripts/nuget/build/native/pugixml-propertiesui.xml @@ -0,0 +1,15 @@ +<?xml version="1.0" encoding="utf-8"?>
+<ProjectSchemaDefinitions xmlns="clr-namespace:Microsoft.Build.Framework.XamlTypes;assembly=Microsoft.Build.Framework">
+ <Rule Name="ReferencedPackages05032e35-86af-4ab2-a3dc-d3e348583165" PageTemplate="tool" DisplayName="Referenced Packages" SwitchPrefix="/" Order="1">
+ <Rule.Categories>
+ <Category Name="pugixml" DisplayName="pugixml" />
+ </Rule.Categories>
+ <Rule.DataSource>
+ <DataSource Persistence="ProjectFile" ItemType="" />
+ </Rule.DataSource>
+ <EnumProperty Name="Linkage-pugixml" DisplayName="Linkage" Description="Which version of the .lib file to link to this library" Category="pugixml">
+ <EnumValue Name="dynamic" DisplayName="dynamic" />
+ <EnumValue Name="static" DisplayName="static" />
+ </EnumProperty>
+ </Rule>
+</ProjectSchemaDefinitions>
diff --git a/scripts/nuget/build/native/pugixml.targets b/scripts/nuget/build/native/pugixml.targets new file mode 100644 index 0000000..97d13b2 --- /dev/null +++ b/scripts/nuget/build/native/pugixml.targets @@ -0,0 +1,27 @@ +<?xml version="1.0" encoding="utf-8"?>
+<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+ <PropertyGroup Label="Default initializers for properties">
+ <Linkage-pugixml Condition="'$(Linkage-pugixml)' == ''">dynamic</Linkage-pugixml>
+ </PropertyGroup>
+ <ItemGroup>
+ <PropertyPageSchema Include="$(MSBuildThisFileDirectory)\pugixml-propertiesui.xml" />
+ </ItemGroup>
+ <ItemDefinitionGroup>
+ <ClCompile>
+ <AdditionalIncludeDirectories>$(MSBuildThisFileDirectory)include/;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+ </ClCompile>
+ <ResourceCompile>
+ <AdditionalIncludeDirectories>$(MSBuildThisFileDirectory)include/;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+ </ResourceCompile>
+ </ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="$(Configuration.ToLower().IndexOf('debug')) != -1">
+ <Link>
+ <AdditionalDependencies>$(MSBuildThisFileDirectory)lib/$(Platform)\$(PlatformToolset.Split('_')[0])\$(Linkage-pugixml)\Debug\pugixml.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ </Link>
+ </ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="$(Configuration.ToLower().IndexOf('debug')) == -1">
+ <Link>
+ <AdditionalDependencies>$(MSBuildThisFileDirectory)lib/$(Platform)\$(PlatformToolset.Split('_')[0])\$(Linkage-pugixml)\Release\pugixml.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ </Link>
+ </ItemDefinitionGroup>
+</Project>
diff --git a/scripts/nuget/pugixml.nuspec b/scripts/nuget/pugixml.nuspec new file mode 100644 index 0000000..abaa7c6 --- /dev/null +++ b/scripts/nuget/pugixml.nuspec @@ -0,0 +1,20 @@ +<?xml version="1.0" encoding="utf-8"?>
+<package xmlns="http://schemas.microsoft.com/packaging/2011/10/nuspec.xsd">
+ <metadata>
+ <id>pugixml</id>
+ <version>1.8.0-appveyor</version>
+ <title>pugixml</title>
+ <authors>Arseny Kapoulkine</authors>
+ <owners>Arseny Kapoulkine</owners>
+ <requireLicenseAcceptance>false</requireLicenseAcceptance>
+ <licenseUrl>http://pugixml.org/license.html</licenseUrl>
+ <projectUrl>http://pugixml.org/</projectUrl>
+ <iconUrl>https://github.com/zeux/pugixml/logo.svg</iconUrl>
+ <description>pugixml is a C++ XML processing library, which consists of a DOM-like interface with rich traversal/modification capabilities, an extremely fast XML parser which constructs the DOM tree from an XML file/buffer, and an XPath 1.0 implementation for complex data-driven tree queries. Full Unicode support is also available, with Unicode interface variants and conversions between different Unicode encodings (which happen automatically during parsing/saving).
+ pugixml is used by a lot of projects, both open-source and proprietary, for performance and easy-to-use interface.</description>
+ <summary>Light-weight, simple and fast XML parser for C++ with XPath support</summary>
+ <releaseNotes>http://pugixml.org/docs/manual.html#changes</releaseNotes>
+ <copyright>Copyright (c) 2006-2017 Arseny Kapoulkine</copyright>
+ <tags>native nativepackage</tags>
+ </metadata>
+</package>
\ No newline at end of file |