Nice3point.Revit.Build.Tasks 3.0.0-preview.1.5

Prefix Reserved
This is a prerelease version of Nice3point.Revit.Build.Tasks.
dotnet add package Nice3point.Revit.Build.Tasks --version 3.0.0-preview.1.5                
NuGet\Install-Package Nice3point.Revit.Build.Tasks -Version 3.0.0-preview.1.5                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Nice3point.Revit.Build.Tasks" Version="3.0.0-preview.1.5" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Nice3point.Revit.Build.Tasks --version 3.0.0-preview.1.5                
#r "nuget: Nice3point.Revit.Build.Tasks, 3.0.0-preview.1.5"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Nice3point.Revit.Build.Tasks as a Cake Addin
#addin nuget:?package=Nice3point.Revit.Build.Tasks&version=3.0.0-preview.1.5&prerelease

// Install Nice3point.Revit.Build.Tasks as a Cake Tool
#tool nuget:?package=Nice3point.Revit.Build.Tasks&version=3.0.0-preview.1.5&prerelease                

Revit Build Tasks

Nuget Downloads Last Commit

This repository contains the MSBuild tasks for developing and publishing the plugin for multiple Revit versions.

Installation

You can install Tasks as a nuget package.

<PackageReference Include="Nice3point.Revit.Build.Tasks" Version="2.*"/>

How to use this package? Just add it to your add-in, and this package will setup the project for simplified maintenance and development. About MSBuild targets.

Package included by default in Revit Templates.

MSBuild Targets

OR_GREATER preprocessor symbols

Included a target for generating the Define Constants needed to support code for multiple Revit versions. OR_GREATER variants are accumulative in nature and provide a simpler way to write compilation conditions.

Current configuration Project configurations Generated define constants
Debug R20 Debug R20, Release R21, Release 2022 REVIT2020, REVIT2020_OR_GREATER
Release R21 Debug R20, Release R21, Release 2022 REVIT2021, REVIT2020_OR_GREATER, REVIT2021_OR_GREATER
Release 2022 Debug R20, Release R21, Release 2022 REVIT2022, REVIT2020_OR_GREATER, REVIT2021_OR_GREATER, REVIT2022_OR_GREATER

Usage:

#if REVIT2021_OR_GREATER
    UnitUtils.ConvertFromInternalUnits(69, UnitTypeId.Millimeters);
#else
    UnitUtils.ConvertFromInternalUnits(69, DisplayUnitType.DUT_MILLIMETERS);
#endif

To support removed APIs in newer versions of Revit, you can invert the constant:

#if !REVIT2023_OR_GREATER
    var builtinCategory = (BuiltInCategory) category.Id.IntegerValue;
#endif

Constants are generated from the names of project configurations. If your project configurations do not contain metadata about the version, you can specify it explicitly:

<PropertyGroup>
    <RevitVersion>2025</RevitVersion>
</PropertyGroup>

To disable preprocessor symbols, set:

<PropertyGroup>
    <DisableImplicitRevitDefines>true</DisableImplicitRevitDefines>
</PropertyGroup>

Publishing

Included a target for copying Revit add-in files to the %AppData%\Autodesk\Revit\Addins folder after building a project.

Clean solution or Clean project will delete the published files.

Copying files helps attach the debugger to the add-in when Revit starts. This makes it easier to test the application or can be used for local development.

Should only be enabled in projects containing the Revit manifest file (.addin).

<PropertyGroup>
    <PublishRevitAddin>true</PublishRevitAddin>
</PropertyGroup>

PublishRevitAddin disabled by default.

If you need to create an installer or a bundle but don't want to publish files to the %AppData%\Autodesk\Revit\Addins directory, use the PublishRevitFiles property instead:

<PropertyGroup>
    <PublishRevitFiles>true</PublishRevitFiles>
</PropertyGroup>

Filed will be published to the bin\publish folder.

PublishRevitFiles disabled by default.

By default, all project files and dependencies required for the plugin to run, including the .addin manifest, are copied. If you need to include additional files, such as configuration or family files, include them in the Content item.

<ItemGroup>
    <Content Include="Resources\Families\Window.rfa" CopyToPublishDirectory="Always"/>
    <Content Include="Resources\Music\Click.wav" CopyToPublishDirectory="PreserveNewest"/>
    <Content Include="Resources\Images\**" CopyToPublishDirectory="PreserveNewest"/>
</ItemGroup>

To enable copying Content files, set CopyToPublishDirectory="Always" or CopyToPublishDirectory="PreserveNewest"

The PublishDirectory property specifies which subfolder of the plugin the file should be copied to. If it is not specified, the files will be copied to the root folder.

<ItemGroup>
    <Content Include="Resources\Families\Window.rfa" PublishDirectory="Families" CopyToPublishDirectory="PreserveNewest"/>
    <Content Include="Resources\Music\Click.wav" PublishDirectory="Music\Effects" CopyToPublishDirectory="PreserveNewest"/>
    <Content Include="Resources\Images\**" PublishDirectory="Images" CopyToPublishDirectory="PreserveNewest"/>
    <Content Include="Readme.md" CopyToPublishDirectory="PreserveNewest"/>
</ItemGroup>

Result:

📂bin\publish; %AppData%\Autodesk\Revit\Addins\2025
 ┣📜RevitAddIn.addin
 ┗📂RevitAddIn
   ┣📂Families
   ┃ ┗📜Family.rfa
   ┣📂Images
   ┃ ┣📜Image.png
   ┃ ┣📜Image2.png
   ┃ ┗📜Image3.jpg
   ┣📂Music
   ┃ ┗📂Effects
   ┃   ┗📜Click.wav
   ┣📜CommunityToolkit.Mvvm.dll
   ┣📜RevitAddIn.dll
   ┗📜Readme.md

Implicit global usings

Included a target for generating implicit global Usings depending on the project references. Helps to reduce the frequent use of using in a project.

Global Using Enabled by reference
using Autodesk.Revit.DB; RevitAPI.dll
using JetBrains.Annotations; JetBrains.Annotations.dll
using Nice3point.Revit.Extensions; Nice3point.Revit.Extensions.dll
using Nice3point.Revit.Toolkit; Nice3point.Revit.Toolkit.dll
using CommunityToolkit.Mvvm.Input; CommunityToolkit.Mvvm.dll
using CommunityToolkit.Mvvm.ComponentModel; CommunityToolkit.Mvvm.dll

To disable it, set:

<PropertyGroup>
    <DisableImplicitRevitUsings>true</DisableImplicitRevitUsings>
    
    <ImplicitUsings>false</ImplicitUsings>
</PropertyGroup>

MSBuild Properties

By default, some properties that are optimal for publishing an application are overriden:

Property Default value Description
AppendTargetFrameworkToOutputPath false Prevents the TFM from being appended to the output path. Required to publish an application

These properties are automatically applied to the .csproj file by default and can be overriden:

<PropertyGroup>
    <AppendTargetFrameworkToOutputPath>false</AppendTargetFrameworkToOutputPath>
</PropertyGroup>
There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

  • .NETFramework 4.8

    • No dependencies.
  • net8.0

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Nice3point.Revit.Build.Tasks:

Package Downloads
xml.Revit.Toolkit

Revit快速开发工具拓展包 xml.Revit.Toolkit.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on Nice3point.Revit.Build.Tasks:

Repository Stars
jeremytammik/RevitLookup
Interactive Revit RFA and RVT project database exploration tool to view and navigate BIM element parameters, properties and relationships.
Nice3point/RevitTemplates
Templates for creating Revit add-ins
Version Downloads Last updated
3.0.0-preview.1.5 93 1/12/2025
2.0.2 8,578 6/19/2024
2.0.1 119 6/19/2024
2.0.0 887 5/20/2024
1.1.2 5,102 4/13/2024
1.1.1 201 4/13/2024
1.1.0 278 4/6/2024
1.0.0 345 4/2/2024

- Property `PublishAddinFiles` renamed to `PublishRevitAddin`.
- Added new property `PublishRevitFiles`, to publish files to the `bin/publish` folder.
- Disabled `EnableDynamicLoading` property by default