Candoumbe.Types.Strings
0.5.0
dotnet add package Candoumbe.Types.Strings --version 0.5.0
NuGet\Install-Package Candoumbe.Types.Strings -Version 0.5.0
<PackageReference Include="Candoumbe.Types.Strings" Version="0.5.0" />
<PackageVersion Include="Candoumbe.Types.Strings" Version="0.5.0" />
<PackageReference Include="Candoumbe.Types.Strings" />
paket add Candoumbe.Types.Strings --version 0.5.0
#r "nuget: Candoumbe.Types.Strings, 0.5.0"
#:package Candoumbe.Types.Strings@0.5.0
#addin nuget:?package=Candoumbe.Types.Strings&version=0.5.0
#tool nuget:?package=Candoumbe.Types.Strings&version=0.5.0
Types
Various custom types that can be useful when doing development.
Disclaimer
This project adheres to Semantic Versioning.
Major version zero (0.y.z) is for initial development. Anything MAY change at any time.
The public API SHOULD NOT be considered stable.
How it all started
This project was born out of frustration encountered while developing a matching algorithm in a professional context. The goal of that project was to enable the effective matching of one or more temporary workers based on :
- the assignment dates
- the declared availability of collaborators.
- their qualification ...
With the team back then, it took several weeks to get this "planning matcher" to work properly and, at the time, I was not very happy with the result (specifically with the planning matching part of the algorithm).
That's how I started working on types from Candoumbe.Types.Calendar namespace.
Features
All following features depend on Candoumbe.Types.Core package.
Calendar
Calendar namespace contains various types related to calendar operations, such as:
DateTimeRange: a datetime range represents a interval between twoDateTimesDateOnlyRange: an interval between twoDateOnlysTimeOnlyRange: an interval between twoTimeOnlys
Numerics
Numerics namespace contains various types useful when you want to work with very specific numeric values such as:
NonNegativeInteger: a type that can only hold non-negative integersPositiveInteger: a type that can only hold integer values greater than zero.
Strings
Strings namespace contains various string-like data
StringSegmentLinkedList
A StringSegmentLinkedList is a special IEnumerable<char>
implementation
that can be used to perform highly performant "replace"
classDiagram
direction RL
namespace Strings {
class StringSegmentNode {
+ ReadonlyMemory~char~ Value
}
class StringSegmentLinkedList {
- StringSegmentNode head
- StringSegmentNode tail
+ Append(ReadOnlySpan~char~) StringSegmentLinkedList
+ Append(StringSegmentLinkedList) StringSegmentLinkedList
+ Contains(ReadOnlySpan~char~) bool
+ Contains(Func~char,bool~) bool
+ Replace(Func~char,bool~ predicate, ReadOnlySpan~char~ newValue) StringSegmentLinkedList
+ Replace(Func~char,bool~ predicate, IReadOnlyDictionaryOfChar~ReadOnlyMemory~char~~ substitutions) StringSegmentLinkedList
+ Replace(char oldValue, char newValue) StringSegmentLinkedList
+ Replace(char oldValue, ReadOnlySpan<char> newValue) StringSegmentLinkedList
+ Replace(ReadOnlySpan~char~ oldValue, ReadOnlySpan<char> newValue) StringSegmentLinkedList
}
}
IEnumerableOfReadOnlyMemory~char~ <|-- StringSegmentLinkedList
StringSegmentLinkedList "1" --> "1" StringSegmentNode: head
StringSegmentLinkedList "0" .. "1" StringSegmentNode: tail
Contributing
Contributions are welcome! Feel free to submit issues or pull requests to improve the project. License
This project is licensed under the MIT License. See the LICENSE file for more details.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. 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 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. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Ardalis.GuardClauses (>= 5.0.0)
- Candoumbe.MiscUtilities (>= 0.15.0)
- FluentValidation (>= 11.12.0)
- Optional (>= 4.0.0)
-
.NETStandard 2.1
- Ardalis.GuardClauses (>= 5.0.0)
- Candoumbe.MiscUtilities (>= 0.15.0)
- FluentValidation (>= 11.12.0)
- Optional (>= 4.0.0)
-
net10.0
- Ardalis.GuardClauses (>= 5.0.0)
- Candoumbe.MiscUtilities (>= 0.15.0)
- FluentValidation (>= 11.12.0)
- Optional (>= 4.0.0)
-
net8.0
- Ardalis.GuardClauses (>= 5.0.0)
- Candoumbe.MiscUtilities (>= 0.15.0)
- FluentValidation (>= 11.12.0)
- Ultimately (>= 3.0.0)
-
net9.0
- Ardalis.GuardClauses (>= 5.0.0)
- Candoumbe.MiscUtilities (>= 0.15.0)
- FluentValidation (>= 11.12.0)
- Ultimately (>= 3.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 0.5.0 | 274 | 11/27/2025 |
| 0.4.2 | 338 | 11/11/2025 |
| 0.4.2-fix.1 | 192 | 8/26/2025 |
| 0.4.1 | 359 | 8/12/2025 |
| 0.4.1-beta.1 | 134 | 8/12/2025 |
| 0.4.0 | 262 | 8/7/2025 |
| 0.4.0-rc.133 | 81 | 8/1/2025 |
| 0.3.1 | 215 | 7/27/2025 |
| 0.3.1-fix.1 | 68 | 7/19/2025 |
| 0.3.0 | 181 | 7/13/2025 |
| 0.3.0-rc.380 | 140 | 6/25/2025 |
| 0.3.0-rc.103 | 142 | 7/13/2025 |
| 0.3.0-rc.101 | 134 | 7/13/2025 |
### 🚀 New features
• Added net10.0 TFM support ([#346](https://github.com/candoumbe/candoumbe.types/issues/346))
• Added netstandard2.0 TFM support ([#355](https://github.com/candoumbe/candoumbe.types/issues/355))
• Added StringSegmentLinkedList.EndsWith(ReadOnlySpan<char>,IEqualityComparer<char>) method ([#287](https://github.com/candoumbe/candoumbe.types/issues/287))
• Optimized memory usage of StringSegmentLinkedList
• Added new constructors for StringSegmentNode and StringSegmentLinkedList
• Improved Append and InsertAt methods to handle different types of inputs
• Added Compact method to reduce node count and improve locality
### 🧹 Housekeeping
• Removed unnecessary imports and simplify code
• Added performance tests for StringSegmentLinkedList
Full changelog at https://github.com/candoumbe/Candoumbe.Types/blob/main/CHANGELOG.md