Bullseye 6.0.0
dotnet add package Bullseye --version 6.0.0
NuGet\Install-Package Bullseye -Version 6.0.0
<PackageReference Include="Bullseye" Version="6.0.0" />
<PackageVersion Include="Bullseye" Version="6.0.0" />
<PackageReference Include="Bullseye" />
paket add Bullseye --version 6.0.0
#r "nuget: Bullseye, 6.0.0"
#:package Bullseye@6.0.0
#addin nuget:?package=Bullseye&version=6.0.0
#tool nuget:?package=Bullseye&version=6.0.0
Bullseye
Bullseye is a .NET library that runs a target dependency graph.
Bullseye is primarily designed as a build tool for .NET projects, and is usually used together with SimpleExec, but Bullseye targets can do anything. They are not restricted to building .NET projects.
Platform support: .NET 6.0 and later.
- Quick start
- Sample wrapper scripts
- Enumerable inputs
- Command-line arguments
- Non-static API
- NO_COLOR
- Who's using Bullseye?
Quick start
- Next to an existing .NET solution ( - .slnfile), add a .NET console app named- targets—- dotnet new console --name targets
- Change to the new directory — - cd targets
- Add a reference to Bullseye — - dotnet add package Bullseye
- Add a reference to SimpleExec — - dotnet add package SimpleExec
- Replace the contents of - targets/Program.cswith:- using static Bullseye.Targets; using static SimpleExec.Command; Target("build", () => RunAsync("dotnet", "build --configuration Release --nologo --verbosity quiet")); Target("test", dependsOn: ["build"], () => RunAsync("dotnet", "test --configuration Release --no-build --nologo --verbosity quiet")); Target("default", dependsOn: ["test"]); await RunTargetsAndExitAsync(args, ex => ex is SimpleExec.ExitCodeException);
- Change to the solution directory — - cd ..
- Run the targets project — - dotnet run --project targets.
Voilà! You've just written and run your first Bullseye build program. You will see output similar to:
<img src="https://github.com/adamralph/bullseye/assets/677704/2f598c2f-89ab-43dc-929a-59f4504dfa28" width="1088px" alt="Bullseye quick start output"/>
For help, run dotnet run --project targets --help.
Sample wrapper scripts
- build(Linux and macOS)- #!/usr/bin/env bash set -euo pipefail dotnet run --project targets -- "$@"
- build.cmd(Windows)- @echo Off dotnet run --project targets -- %*
Enumerable inputs
For example, you may want to run your test projects one by one, so that the timing of each one and which one, if any, failed, is displayed in the Bullseye build summary:
Target(
    "test",
    dependsOn: ["build"],
    forEach: ["./FooTests.Acceptance", "./FooTests.Performance"],
    project => RunAsync($"dotnet", $"test {project} --configuration Release --no-build --nologo --verbosity quiet"));
dotnet run -- test
<img src="https://github.com/adamralph/bullseye/assets/677704/c25901c6-f30b-4632-8b62-fa3a755729fc" width="1085px" alt="Bullseye enumerable inputs output"/>
Command-line arguments
Generally, all the command-line arguments passed to Program.cs should be passed along to Bullseye, as shown in the quick start above (RunTargetsAndExitAsync(args);). This is because Bullseye effectively provides a command-line interface, with options for displaying a list of targets, performing dry runs, suppressing colour, and more. For full details of the command-line options, run your targets project supplying the --help (-h/-?) option:
dotnet run --project targets -- --help
./build --help
./build.cmd --help
You can also handle custom arguments in Program.cs, but you should ensure that only valid arguments are passed along to Bullseye and that the help text contains both your custom arguments and the arguments supported by Bullseye. A good way to do this is to use a command-line parsing package to define your custom arguments, and to provide translation between the package and Bullseye. For example, see the test projects for:
Non-static API
For most cases, the static API described above is sufficient. For more complex scenarios where a number of target collections are required, the non-static API may be used.
var targets1 = new Targets();
targets1.Add("foo", () => Console.Out.WriteLine("foo1"));
var targets2 = new Targets();
targets2.Add("foo", () => Console.Out.WriteLine("foo2"));
await targets1.RunWithoutExitingAsync(args);
await targets2.RunWithoutExitingAsync(args);
NO_COLOR
Bullseye supports NO_COLOR.
Who's using Bullseye?
To name a few:
- AspNetCore.AsyncInitialization
- Config.SqlStreamStore
- ConfigR
- Elastic
- EssentialMVVM
- FakeItEasy
- Fluxzy
- HumanBytes
- Ibento
- IdentityModel
- IdentityServer
- Iso8601DurationHelper
- Linq.Extras
- LittleForker
- LykkeOSS
- Marten
- MinVer
- Particular
- ProxyKit
- PseudoLocalizer
- Radical Framework
- RealWorld
- SelfInitializingFakes
- SendComics
- SqlStreamStore.Locking
- SQLStreamStore
- Statik
- Tasty
- TemplatedConfiguration
- Xenial
Feel free to send a pull request to add your repository or organisation to this list!
<sub>Target by Franck Juncker from the Noun Project.</sub>
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
- 
                                                    net8.0- No dependencies.
 
- 
                                                    net9.0- No dependencies.
 
NuGet packages (8)
Showing the top 5 NuGet packages that depend on Bullseye:
| Package | Downloads | 
|---|---|
| Apprio.Enablement.Infrastructure Package Description | |
| Faithlife.Build A build automation system using C# build scripts. | |
| Apprio.Azure.Infrastructure Package Description | |
| Dex.IdentityServer4 OpenID Connect and OAuth 2.0 Framework for ASP.NET Core | |
| Xenial.Beer Beer - Delicious dotnet build tools | 
GitHub repositories (45)
Showing the top 20 popular GitHub repositories that depend on Bullseye:
| Repository | Stars | 
|---|---|
| xunit/xunit 
                                                            xUnit.net is a free, open source, community-focused unit testing tool for .NET.
                                                         | |
| elastic/elasticsearch-net 
                                                            This strongly-typed, client library enables working with Elasticsearch. It is the official client maintained and supported by Elastic.
                                                         | |
| aaubry/YamlDotNet 
                                                            YamlDotNet is a .NET library for YAML
                                                         | |
| adamhathcock/sharpcompress 
                                                            SharpCompress is a fully managed C# library to deal with many compression types and formats.
                                                         | |
| AppMetrics/AppMetrics 
                                                            App Metrics is an open-source and cross-platform .NET library used to record and report metrics within an application.
                                                         | |
| gothinkster/aspnetcore-realworld-example-app 
                                                            ASP.NET Core backend implementation for RealWorld
                                                         | |
| servicetitan/Stl.Fusion 
                                                            Build real-time apps (Blazor included) with less than 1% of extra code responsible for real-time updates. Host 10-1000x faster APIs relying on transparent and nearly 100% consistent caching. We call it DREAM, or Distributed REActive Memoization, and it's here to turn real-time on!
                                                         | |
| FakeItEasy/FakeItEasy 
                                                            The easy mocking library for .NET
                                                         | |
| ProxyKit/ProxyKit 
                                                            A toolkit to create code-first HTTP reverse proxies on ASP.NET Core
                                                         | |
| DuendeArchive/IdentityModel 
                                                            .NET standard helper library for claims-based identity, OAuth 2.0 and OpenID Connect.
                                                         | |
| adamralph/minver 
                                                            🏷 Minimalistic versioning using Git tags.
                                                         | |
| machine/machine.specifications 
                                                            Machine.Specifications is a Context/Specification framework for .NET that removes language noise and simplifies tests.
                                                         | |
| DuendeArchive/IdentityModel.OidcClient 
                                                            Certified C#/NetStandard OpenID Connect Client Library for native mobile/desktop Applications (RFC 8252)
                                                         | |
| JasperFx/lamar 
                                                            Fast Inversion of Control Tool and Successor to StructureMap
                                                         | |
| elastic/apm-agent-dotnet | |
| Particular/Workshop 
                                                            SOA Done Right
                                                         | |
| Librelancer/Librelancer 
                                                            A re-implementation of Freelancer
                                                         | |
| SQLStreamStore/SQLStreamStore 
                                                            Stream Store library targeting RDBMS based implementations for .NET
                                                         | |
| XamlAnimatedGif/XamlAnimatedGif 
                                                            A simple library to display animated GIF images in WPF apps (.NET Framework 4.5, .NET Core 3.1, .NET 5.0)
                                                         | |
| config-r/config-r 
                                                            Write your .NET configuration files in C#
                                                         | 
| Version | Downloads | Last Updated | 
|---|---|---|
| 6.0.0 | 68,123 | 4/2/2025 | 
| 6.0.0-beta.2 | 1,773 | 3/10/2025 | 
| 6.0.0-beta.1 | 651 | 2/23/2025 | 
| 5.0.0 | 517,047 | 1/15/2024 | 
| 5.0.0-rc.1 | 641 | 12/21/2023 | 
| 5.0.0-alpha.2 | 951 | 9/25/2023 | 
| 5.0.0-alpha.1 | 1,070 | 6/9/2023 | 
| 4.2.1 | 258,817 | 1/24/2023 | 
| 4.2.1-rc.1 | 649 | 12/3/2022 | 
| 4.2.0 | 71,679 | 11/9/2022 | 
| 4.2.0-beta.1 | 475 | 10/30/2022 | 
| 4.1.1 | 40,135 | 10/22/2022 | 
| 4.1.0 | 1,264 | 10/16/2022 | 
| 4.1.0-rc.1 | 329 | 10/9/2022 | 
| 4.1.0-alpha.2 | 495 | 8/28/2022 | 
| 4.1.0-alpha.1 | 4,207 | 3/13/2022 | 
| 4.0.0 | 170,246 | 3/12/2022 | 
| 4.0.0-rc.3 | 412 | 3/11/2022 | 
| 4.0.0-rc.2 | 7,659 | 12/30/2021 | 
| 4.0.0-rc.1 | 402 | 12/23/2021 | 
| 4.0.0-beta.1 | 2,997 | 11/7/2021 | 
| 4.0.0-alpha.2 | 368 | 11/6/2021 | 
| 4.0.0-alpha.1 | 709 | 9/19/2021 | 
| 3.8.0 | 1,409,818 | 8/20/2021 | 
| 3.8.0-rc.1 | 584 | 8/3/2021 | 
| 3.8.0-beta.1 | 366 | 7/28/2021 | 
| 3.8.0-alpha.2 | 312 | 7/25/2021 | 
| 3.8.0-alpha.1 | 342 | 7/25/2021 | 
| 3.7.1 | 35,255 | 7/12/2021 | 
| 3.7.0 | 742,183 | 1/20/2021 | 
| 3.7.0-alpha.1 | 722 | 1/7/2021 | 
| 3.6.0 | 41,357 | 1/1/2021 | 
| 3.6.0-rc.1 | 1,415 | 12/22/2020 | 
| 3.6.0-beta.1 | 430 | 12/4/2020 | 
| 3.5.0 | 126,195 | 9/19/2020 | 
| 3.5.0-rc.1 | 615 | 9/4/2020 | 
| 3.4.0 | 53,385 | 7/26/2020 | 
| 3.4.0-alpha.1 | 580 | 6/24/2020 | 
| 3.3.0 | 280,169 | 4/2/2020 | 
| 3.3.0-beta.1 | 539 | 3/6/2020 | 
| 3.2.0 | 14,491 | 2/20/2020 | 
| 3.2.0-rc.1 | 561 | 2/9/2020 | 
| 3.2.0-alpha.2 | 760 | 12/26/2019 | 
| 3.2.0-alpha.1 | 532 | 12/23/2019 | 
| 3.1.0 | 118,906 | 12/7/2019 | 
| 3.1.0-rc.1 | 1,122 | 11/13/2019 | 
| 3.1.0-alpha.1 | 650 | 10/16/2019 | 
| 3.0.0 | 66,483 | 10/13/2019 | 
| 3.0.0-rc.1 | 4,395 | 9/8/2019 | 
| 3.0.0-beta.3 | 934 | 8/27/2019 | 
| 3.0.0-beta.2 | 284 | 8/25/2019 | 
| 3.0.0-beta.1 | 310 | 8/25/2019 | 
| 3.0.0-alpha.1 | 302 | 8/24/2019 | 
| 2.4.0 | 6,920 | 7/27/2019 | 
| 2.4.0-rc.2 | 19,135 | 7/15/2019 | 
| 2.4.0-rc.1 | 285 | 7/15/2019 | 
| 2.4.0-beta.1 | 776 | 6/28/2019 | 
| 2.4.0-alpha.1 | 2,296 | 6/1/2019 | 
| 2.3.0 | 70,694 | 12/17/2018 | 
| 2.3.0-rc.1 | 2,312 | 12/14/2018 | 
| 2.3.0-beta.6 | 931 | 12/8/2018 | 
| 2.3.0-beta.5 | 411 | 12/8/2018 | 
| 2.3.0-beta.4 | 380 | 12/7/2018 | 
| 2.3.0-beta.3 | 423 | 12/4/2018 | 
| 2.3.0-beta.2 | 418 | 11/30/2018 | 
| 2.3.0-beta.1 | 382 | 11/27/2018 | 
| 2.3.0-alpha.1 | 456 | 11/2/2018 | 
| 2.2.0 | 5,454 | 10/19/2018 | 
| 2.2.0-rc.2 | 436 | 10/13/2018 | 
| 2.2.0-rc.1 | 429 | 10/13/2018 | 
| 2.2.0-beta.2 | 438 | 10/12/2018 | 
| 2.2.0-beta.1 | 425 | 10/11/2018 | 
| 2.1.0 | 7,029 | 10/9/2018 | 
| 2.1.0-beta.1 | 433 | 10/7/2018 | 
| 2.0.0 | 1,280 | 10/7/2018 | 
| 2.0.0-rc.3 | 578 | 9/30/2018 | 
| 2.0.0-rc.2 | 479 | 9/27/2018 | 
| 2.0.0-rc.1 | 425 | 9/26/2018 | 
| 1.3.0 | 1,892 | 9/20/2018 | 
| 1.2.0 | 5,737 | 9/3/2018 | 
| 1.2.0-rc.2 | 13,999 | 9/2/2018 | 
| 1.2.0-rc.1 | 449 | 9/2/2018 | 
| 1.1.0 | 1,363 | 8/23/2018 | 
| 1.1.0-rc.2 | 550 | 8/13/2018 | 
| 1.1.0-rc.1 | 592 | 8/12/2018 | 
| 1.0.1 | 1,396 | 8/2/2018 | 
| 1.0.0 | 3,329 | 7/27/2018 | 
| 1.0.0-rc.5 | 726 | 6/28/2018 | 
| 1.0.0-rc.4 | 681 | 6/26/2018 | 
| 1.0.0-rc.3 | 563 | 6/26/2018 | 
| 1.0.0-rc.2 | 607 | 6/24/2018 | 
| 1.0.0-rc.1 | 2,047 | 5/6/2018 | 
| 1.0.0-alpha0002 | 1,185 | 11/17/2017 | 
| 1.0.0-alpha0001 | 1,230 | 11/17/2017 |