ktsu.IntervalAction 1.3.3

ktsu.IntervalAction

A .NET library that provides a simple way to execute an action at a specified interval.

License NuGet Version NuGet Version NuGet Downloads GitHub commit activity GitHub contributors GitHub Actions Workflow Status

Introduction

IntervalAction is a .NET library that provides a simple and flexible way to execute an action at a specified interval. It offers precise control over execution timing, various interval types, and easy management of scheduled actions. Designed for scenarios where you need recurring tasks like polling, background processing, or timed updates.

Features

  • Flexible Timing: Execute actions at precise intervals
  • Interval Types: Choose between running intervals from last start or last completion
  • Configurable Polling: Fine-tune polling frequency for better performance
  • Immediate Execution: Option to execute actions immediately on start
  • Start/Stop Control: Easily pause and restart scheduled actions
  • Thread Safety: Safe for concurrent access from multiple threads
  • Low Overhead: Minimal resource usage during idle periods
  • Supports .NET 8.0 and .NET 9.0: Modern .NET support

Installation

Package Manager Console

Install-Package ktsu.IntervalAction

.NET CLI

dotnet add package ktsu.IntervalAction

Package Reference

<PackageReference Include="ktsu.IntervalAction" Version="x.y.z" />

Usage Examples

Basic Example

using ktsu.IntervalAction;

var intervalAction = IntervalAction.Start(new()
{
    Action = () => Console.WriteLine("Hello, World!"),
    ActionInterval = TimeSpan.FromSeconds(1),
    PollingInterval = TimeSpan.FromMilliseconds(100), // Optional, default is 1 second
    IntervalType = IntervalType.FromLastStart // Optional, default is FromLastCompletion
});

// An action will execute immediately and then every second
// outputting "Hello, World!" to the console until stopped

intervalAction.Stop();

// The action will no longer execute until you call Restart()

intervalAction.Restart();

Using FromLastCompletion Interval Type

using ktsu.IntervalAction;

var intervalAction = IntervalAction.Start(new()
{
    Action = () =>
    {
        Console.WriteLine($"Action started at: {DateTimeOffset.Now}");
        // Simulate a task that takes some time to complete
        Task.Delay(500).Wait();
        Console.WriteLine($"Action completed at: {DateTimeOffset.Now}");
    },
    ActionInterval = TimeSpan.FromSeconds(2),
    PollingInterval = TimeSpan.FromMilliseconds(100),
    IntervalType = IntervalType.FromLastCompletion // Waits until the action completes before starting the interval timer
});

// The action will execute immediately and then every 2 seconds after the previous execution completes

Handling Long-Running Tasks

using ktsu.IntervalAction;

var intervalAction = IntervalAction.Start(new()
{
    Action = async () =>
    {
        Console.WriteLine("Starting long-running task...");
        
        // Simulate a long-running task
        await Task.Delay(5000);
        
        Console.WriteLine("Long-running task completed");
    },
    ActionInterval = TimeSpan.FromSeconds(10),
    IntervalType = IntervalType.FromLastCompletion // Important for long-running tasks
});

// For cleanup when done
await Task.Delay(60000); // Run for 1 minute
intervalAction.Stop();

Dynamic Interval Adjustment

using ktsu.IntervalAction;

// Create with initial settings
var options = new IntervalActionOptions
{
    Action = () => Console.WriteLine($"Tick at {DateTime.Now}"),
    ActionInterval = TimeSpan.FromSeconds(5)
};

var intervalAction = IntervalAction.Start(options);

// Later, adjust the interval
await Task.Delay(20000); // After 20 seconds

intervalAction.Stop();
options.ActionInterval = TimeSpan.FromSeconds(1);
intervalAction.Restart();

Console.WriteLine("Interval changed to 1 second");

API Reference

IntervalAction Class

The main class for scheduling recurring actions.

Properties

Name Type Description
IsRunning bool Indicates if the action is currently scheduled to run
Options IntervalActionOptions The current options for this interval action

Methods

Name Parameters Return Type Description
Start IntervalActionOptions options IntervalAction Static factory method to create and start an interval action
Stop void Stops the scheduled action from running
Restart void Restarts a previously stopped action
Dispose void Cleans up resources and stops the action

IntervalActionOptions Class

Configuration options for an interval action.

Properties

Name Type Description
Action Action The action to execute at intervals (required)
ActionInterval TimeSpan The interval between executions (required)
PollingInterval TimeSpan How frequently to check if action should run (optional, default 1 second)
IntervalType IntervalType Determines how intervals are measured (optional, default FromLastCompletion)

IntervalType Enum

Defines how the interval is measured.

Value Description
FromLastCompletion The interval starts after the action has completed
FromLastStart The interval starts when the action begins executing

Contributing

Contributions are welcome! Here's how you can help:

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

Please make sure to update tests as appropriate and adhere to the existing coding style.

License

This project is licensed under the MIT License - see the LICENSE.md file for details.

Versioning

Check the CHANGELOG.md for detailed release notes and version changes.

Acknowledgements

Special thanks to all contributors and the .NET community for their support.

No packages depend on ktsu.IntervalAction.

## v1.3.3 (patch) Changes since v1.3.2: - Convert to PolySharp ([@Damon3000s](https://github.com/Damon3000s)) ## v1.3.2 (patch) Changes since v1.3.1: - Update configuration files and scripts for improved build and test processes ([@matt-edmondson](https://github.com/matt-edmondson)) - Add CompatibilitySuppressions.xml for .NET compatibility diagnostics and update exception handling in IntervalAction class. Introduce new tests for zero and negative intervals, and ensure Stop method is idempotent. ([@matt-edmondson](https://github.com/matt-edmondson)) - Add configuration files for package management and CI/CD workflows ([@matt-edmondson](https://github.com/matt-edmondson)) ## v1.3.2-pre.17 (prerelease) Changes since v1.3.2-pre.16: - Sync .runsettings ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .gitattributes ([@ktsu[bot]](https://github.com/ktsu[bot])) - Merge remote-tracking branch 'refs/remotes/origin/main' ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .editorconfig ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync scripts\PSBuild.psm1 ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .gitignore ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .mailmap ([@ktsu[bot]](https://github.com/ktsu[bot])) ## v1.3.2-pre.16 (prerelease) Changes since v1.3.2-pre.15: - Sync .runsettings ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .editorconfig ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .gitignore ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .mailmap ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .gitattributes ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync scripts\PSBuild.psm1 ([@ktsu[bot]](https://github.com/ktsu[bot])) ## v1.3.2-pre.15 (prerelease) Changes since v1.3.2-pre.14: ## v1.3.2-pre.14 (prerelease) Changes since v1.3.2-pre.13: ## v1.3.2-pre.13 (prerelease) Changes since v1.3.2-pre.12: ## v1.3.2-pre.12 (prerelease) Changes since v1.3.2-pre.11: ## v1.3.2-pre.11 (prerelease) Changes since v1.3.2-pre.10: ## v1.3.2-pre.10 (prerelease) Changes since v1.3.2-pre.9: ## v1.3.2-pre.9 (prerelease) Changes since v1.3.2-pre.8: ## v1.3.2-pre.8 (prerelease) Changes since v1.3.2-pre.7: ## v1.3.2-pre.7 (prerelease) Changes since v1.3.2-pre.6: ## v1.3.2-pre.6 (prerelease) Changes since v1.3.2-pre.5: ## v1.3.2-pre.5 (prerelease) Changes since v1.3.2-pre.4: ## v1.3.2-pre.4 (prerelease) Changes since v1.3.2-pre.3: ## v1.3.2-pre.3 (prerelease) Changes since v1.3.2-pre.2: ## v1.3.2-pre.2 (prerelease) Changes since v1.3.2-pre.1: ## v1.3.2-pre.1 (prerelease) Incremental prerelease update. ## v1.3.1 (patch) Changes since v1.3.0: - Enhance documentation and update project SDK references. Improved the library description for clarity and added detailed features and usage examples in README. Updated project files to use the latest SDK versions. ([@matt-edmondson](https://github.com/matt-edmondson)) - Remove Directory.Build.props and Directory.Build.targets files; add copyright notices to IntervalAction source files and tests; update variable declarations in tests for consistency. ([@matt-edmondson](https://github.com/matt-edmondson)) ## v1.3.1-pre.2 (prerelease) Changes since v1.3.1-pre.1: - Sync .editorconfig ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .github\workflows\dotnet.yml ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .runsettings ([@ktsu[bot]](https://github.com/ktsu[bot])) ## v1.3.1-pre.1 (prerelease) Incremental prerelease update. ## v1.3.0 (minor) Changes since v1.2.0: - Add LICENSE template ([@matt-edmondson](https://github.com/matt-edmondson)) ## v1.2.1-pre.2 (prerelease) Changes since v1.2.1-pre.1: - Sync scripts\make-changelog.ps1 ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync scripts\make-version.ps1 ([@ktsu[bot]](https://github.com/ktsu[bot])) ## v1.2.1-pre.1 (prerelease) Changes since v1.2.0: - Sync Directory.Build.targets ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .editorconfig ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync .gitignore ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync scripts\make-changelog.ps1 ([@ktsu[bot]](https://github.com/ktsu[bot])) - Sync scripts\make-version.ps1 ([@ktsu[bot]](https://github.com/ktsu[bot])) ## v1.2.0 (minor) Changes since v1.1.0: - Refactor IntervalAction constructor and Start method ([@matt-edmondson](https://github.com/matt-edmondson)) ## v1.1.0 (major) No significant changes detected since v0.1.0. ## v0.1.0 (minor) - Refactor IntervalAction constructor and Start method ([@matt-edmondson](https://github.com/matt-edmondson)) - Initial commit ([@matt-edmondson](https://github.com/matt-edmondson))

.NET 5.0

.NET Standard 2.1

.NET Standard 2.0

.NET 8.0

.NET 7.0

.NET 6.0

.NET 9.0

Version Downloads Last updated
1.3.4-pre.4 15 11/24/2025
1.3.4-pre.3 16 11/23/2025
1.3.4-pre.2 15 11/23/2025
1.3.4-pre.1 16 11/23/2025
1.3.3 19 08/26/2025
1.3.2 18 08/25/2025