Shuttle.Core.Cron
21.0.0-alpha
Prefix Reserved
See the version list below for details.
dotnet add package Shuttle.Core.Cron --version 21.0.0-alpha
NuGet\Install-Package Shuttle.Core.Cron -Version 21.0.0-alpha
<PackageReference Include="Shuttle.Core.Cron" Version="21.0.0-alpha" />
<PackageVersion Include="Shuttle.Core.Cron" Version="21.0.0-alpha" />
<PackageReference Include="Shuttle.Core.Cron" />
paket add Shuttle.Core.Cron --version 21.0.0-alpha
#r "nuget: Shuttle.Core.Cron, 21.0.0-alpha"
#:package Shuttle.Core.Cron@21.0.0-alpha
#addin nuget:?package=Shuttle.Core.Cron&version=21.0.0-alpha&prerelease
#tool nuget:?package=Shuttle.Core.Cron&version=21.0.0-alpha&prerelease
Shuttle.Core.Cron
Provides cron expression parsing:
┌───────────── minute (0 - 59)
│ ┌───────────── hour (0 - 23)
│ │ ┌───────────── day of the month (1 - 31)
│ │ │ ┌───────────── month (1 - 12)
│ │ │ │ ┌───────────── day of the week (1 - 7): Sunday to Saturday
│ │ │ │ │
│ │ │ │ │
│ │ │ │ │
* * * * *
This implementation starts from the minute field (so no second). Any seconds are removed from all dates that are used.
CronExpression
public CronExpression(string expression, ISpecificationFactory specificationFactory = null) : this(expression, DateTime.Now, specificationFactory);
public CronExpression(string expression, DateTime date, ISpecificationFactory specificationFactory = null);
Creates a CronExpression instance and parses the given expression. The date specifies to root date from which to determine either the next or previous occurrence.
public DateTime NextOccurrence();
public DateTime NextOccurrence(DateTime date);
Returns the next date that would follow the given date. This is accomplished by adding 1 muinute to the relevant date. If no date is provided the root date will be used. This method also sets the root date to the result.
public DateTime GetNextOccurrence(DateTime date);
Returns the next date that would follow the given date. If the given date satisfies the required specification(s) then the date is returned as-is.
public DateTime PreviousOccurrence();
public DateTime PreviousOccurrence(DateTime date);
Returns the previous date that would precede the given date. This is accomplished by subtracting 1 muinute from the relevant date. If no date is provided the root date will be used. This method also sets the root date to the result.
public DateTime GetPreviousOccurrence(DateTime date);
Returns the previous date that would precede the given date. If the given date satisfies the required specification(s) then the date is returned as-is.
Cron Samples
Format is {minute} {hour} {day-of-month} {month} {day-of-week}
| Field | Options |
|---|---|
minutes |
0-59 , - * / |
hours |
0-23 , - * / |
day-of-month |
1-31 , - * ? / L W |
month |
1-12 or JAN-DEC , - * / |
day-of-week |
1-7 or SUN-SAT , - * ? / L # |
If day-of-month is specified then day-of-week should be ? and vice-versa.
Examples:
* * * * * - is every minute of every hour of every day of every month
5,10-12,17/5 * * * * - minute 5, 10, 11, 12, and every 5th minute after that
Specifications
Specifications need to implement ISpecification<CronField.Candidate>.
You may pass an implementation of the ISpecificationFactory as a parameter to the CronExpression. There is a DefaultSpecificationFactory that accepts a function callback in the constructor for scenarios where an explicit ISpecificationFactory implementation may not be warranted, e.g.:
var factory = new DefaultSpecificationFactory(parameters =>
{
return !parameters.Expression.Equals("H", StringComparison.InvariantCultureIgnoreCase)
? null
: new Specification<CronField.Candidate>(candidate => candidate.Date.Day % 2 == 0);
});
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. 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. |
-
net10.0
- Shuttle.Core.Contract (>= 21.0.0-alpha)
- Shuttle.Core.Specification (>= 21.0.0-alpha)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Shuttle.Core.Cron:
| Package | Downloads |
|---|---|
|
Shuttle.Esb.Scheduling
Scheduling solution built on Shuttle.Esb. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 21.0.1-rc1 | 85 | 2/28/2026 |
| 21.0.1-beta | 94 | 2/7/2026 |
| 21.0.0-alpha | 93 | 1/18/2026 |
| 20.0.0 | 1,533 | 2/2/2025 |
| 10.1.4 | 867 | 11/6/2024 |
| 10.1.3 | 11,593 | 12/1/2022 |
| 10.1.2 | 1,770 | 9/4/2022 |
| 10.1.0 | 31,225 | 2/23/2020 |
| 10.0.6 | 7,197 | 1/15/2019 |
| 10.0.5 | 11,374 | 7/4/2018 |
| 10.0.4 | 2,423 | 7/3/2018 |
| 10.0.2 | 2,619 | 2/18/2018 |
| 10.0.1 | 2,168 | 2/17/2018 |