Haystack is available as a nuget package targeting .NET Standard 1.3, which means it's compatible with a fairly wide range of .NET runtimes:
- .NET Core 1.0+
- .NET Framework 4.6+
- Mono 4.6+
- UWP 10+
- Unity 2018.1
Haystack uses semantic versioning. In a nutshell:
Given a version number MAJOR.MINOR.PATCH, increment the:
- MAJOR version when you make incompatible API changes,
- MINOR version when you add functionality in a backwards-compatible manner, and
- PATCH version when you make backwards-compatible bug fixes.
Haystack is meant to be a small library that fills in some of the gaps in the BCL. By definition, it's kind of a dumping ground for little helper methods.
I wrote most of these methods myself. Chances are if you're here, you've written many of them in the past, too, and you're tired of writing them again.
There are some implementations that are cobbled together from other sources. When that's the case, I have left a note in the source code indicating where it was taken from.
Generally speaking, if there's more than one obvious way something could be implemented, the best-performing implementation was chosen. There is a performance testing project in the source that indicates where performance testing was done. That said, due to the nature of performance testing, only the best-performing alternative is kept. I.e. there is no performance testing code kept around for the lower-performing alternatives.
See the Haystack wiki.