Fable.Package.SDK
1.0.0
See the version list below for details.
dotnet add package Fable.Package.SDK --version 1.0.0
NuGet\Install-Package Fable.Package.SDK -Version 1.0.0
<PackageReference Include="Fable.Package.SDK" Version="1.0.0" />
paket add Fable.Package.SDK --version 1.0.0
#r "nuget: Fable.Package.SDK, 1.0.0"
// Install Fable.Package.SDK as a Cake Addin #addin nuget:?package=Fable.Package.SDK&version=1.0.0 // Install Fable.Package.SDK as a Cake Tool #tool nuget:?package=Fable.Package.SDK&version=1.0.0
Fable.Package.SDK
Fable.Package.SDK is a set of MSBuild targets and tasks that help you build and package Fable projects.
Features 🚀
- Automatically add Fable specific tags to
PackageTags
based on theFablePackageType
property - Automatically include F# source files in the package if needed
- Check that at least one Fable target is defined in the
PackageTags
property - Set
GenerateDocumentationFile
totrue
- Set up your package for improving IDE experiences by setting:
DebugType
toembedded
EmbedUntrackedSources
totrue
Installation
dotnet add package Fable.Package.SDK
Usage
1. Set the FablePackageType
property
Set the FablePackageType
property in your project file to one of the following values:
library
: If your package is a library that can be used by Fable.Examples of libraries could be Fable.Promise, Elmish, Thoth.Json, Feliz
This will include the source files in the package.
binding
: If your package consist of a set of API to make a native library availableFor example:
- A package which makes an NPM package API available
- A package which makes the Browser API available
- A package which makes a cargo package API available
<br/>
Only the DLL will be included in the package, allowing for a faster build and smaller package size.
2. Specify the targets
Choose one or more of the following tags:
fable-dart
: Dart is supported by the packagefable-dotnet
: .NET is supported by the packagefable-javascript
: JavaScript is supported by the packagefable-python
: Python is supported by the packagefable-rust
: Rust is supported by the packagefable-all
: Package is compatible with all Fable targets.
[!WARNING] A package can be compatible with all targets if it depends only on packages that are also compatible with all targets.
A package compatible with all targets cannot be a binding, as these are target-specific.
Example:
If your package supports only JavaScript you need to use fable-javascript
If your package supports both JavaScript and Python, you need to use fable-javascript
and fable-python
Example of use case
If your package is a binding which target JavaScript you need to write:
<PropertyGroup>
<PackageTags>fable-javascript</PackageTags>
<FablePackageType>binding</FablePackageType>
</PropertyGroup>
If your package is a library which targets JavaScript and Python you need to write:
<PropertyGroup>
<PackageTags>fable-javascript;fable-python</PackageTags>
<FablePackageType>library</FablePackageType>
</PropertyGroup>
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages (3)
Showing the top 3 NuGet packages that depend on Fable.Package.SDK:
Package | Downloads |
---|---|
FCQRS.Model
Package Description |
|
Glutinum.Feliz.ReactSignaturePadWrapper
Package Description |
|
Glutinum.SignaturePad
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
## 1.0.0
### 🐞 Bug Fixes
- Include the original project file instead of `Fable.Package.SDK.targets` ([96f7e39](https://github.com/easybuild-org/EasyBuild.FileSystemProvider/commit/96f7e39fdf55be3b37ec48e1f32be0202677381c))