Commit 75f423e
Complete rewrite and v1.0 release preparation (#146)
## Complete rewrite and v1.0 release preparation
This PR represents a full rewrite of the PolylineAlgorithm library,
modernizing the API surface, improving extensibility, and preparing for
a stable v1.0 release targeting .NET Standard 2.1+.
---
### Breaking Changes / New Public API
- **New generic interfaces** `IPolylineEncoder<TCoordinate, TPolyline>`
and `IPolylineDecoder<TPolyline, TCoordinate>` replace the old encoding
abstraction, allowing callers to use any coordinate and polyline
representation.
- **Abstract base classes** `AbstractPolylineEncoder<TCoordinate,
TPolyline>` and `AbstractPolylineDecoder<TPolyline, TCoordinate>`
provide the shared encoding/decoding algorithm; consumers override only
`GetLatitude`, `GetLongitude`, `CreatePolyline` (encoder) or
`CreateCoordinate`, `GetReadOnlyMemory` (decoder).
- **Extension methods** `PolylineEncoderExtensions` and
`PolylineDecoderExtensions` add convenience overloads for `List<T>` and
arrays.
- **`PolylineEncoding`** static utility class exposes low-level
normalization, validation, encoding and decoding primitives.
- **`PolylineEncodingOptions`** and **`PolylineEncodingOptionsBuilder`**
expose configurable precision, stack-alloc buffer limit and
`ILoggerFactory` integration.
- **`InvalidPolylineException`** added for descriptive error reporting
on malformed input.
- All `Encode`/`Decode` methods accept an optional `CancellationToken`.
### Other Changes
- Integrated `Microsoft.Extensions.Logging` support for diagnostics / CI
audit trails.
- Added `PolylineAlgorithm.NetTopologySuite.Sample` demonstrating
integration with NetTopologySuite.
- Comprehensive XML doc comments on all public APIs.
- Updated README, CONTRIBUTING, AGENTS and all guide docs under
`api-reference/guide/` (getting-started, advanced-scenarios,
configuration, FAQ).
- DocFX API reference updated for v1.0 under `api-reference/1.0/`.
- Updated unit tests and benchmarks.
---------
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: Pete Sramek <petr.sramek@dropoutcoder.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Copilot <198982749+Copilot@users.noreply.github.com>
Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>1 parent a71090d commit 75f423e
147 files changed
Lines changed: 9038 additions & 4969 deletions
File tree
- .github
- actions
- documentation
- docfx-build
- docfx-metadata
- github
- branch-protection
- lock
- unlock
- create-release
- write-file-to-summary
- git/push-changes
- nuget/publish-package
- source
- compile
- format
- testing
- code-coverage
- test-report
- versioning
- extract-version
- format-version
- workflows
- api-reference
- 1.0
- docs-versioning
- layout
- public
- guide
- benchmarks/PolylineAlgorithm.Benchmarks
- Properties
- docs
- samples/PolylineAlgorithm.NetTopologySuite.Sample
- Properties
- src/PolylineAlgorithm
- Abstraction
- Extensions
- Internal
- Diagnostics
- Logging
- Properties
- tests/PolylineAlgorithm.Tests
- Abstraction
- Extensions
- Fakes
- Internal
- Diagnostics
- Properties
- utilities/PolylineAlgorithm.Utility
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
131 | 131 | | |
132 | 132 | | |
133 | 133 | | |
134 | | - | |
| 134 | + | |
135 | 135 | | |
136 | 136 | | |
137 | 137 | | |
| |||
270 | 270 | | |
271 | 271 | | |
272 | 272 | | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
24 | | - | |
25 | | - | |
26 | 24 | | |
27 | 25 | | |
28 | 26 | | |
29 | | - | |
| 27 | + | |
30 | 28 | | |
31 | 29 | | |
32 | 30 | | |
| |||
41 | 39 | | |
42 | 40 | | |
43 | 41 | | |
44 | | - | |
| 42 | + | |
45 | 43 | | |
46 | 44 | | |
47 | 45 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
29 | | - | |
| 29 | + | |
30 | 30 | | |
31 | 31 | | |
32 | 32 | | |
| |||
59 | 59 | | |
60 | 60 | | |
61 | 61 | | |
62 | | - | |
| 62 | + | |
63 | 63 | | |
64 | 64 | | |
65 | 65 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
31 | | - | |
| 31 | + | |
32 | 32 | | |
33 | 33 | | |
34 | 34 | | |
| |||
37 | 37 | | |
38 | 38 | | |
39 | 39 | | |
40 | | - | |
| 40 | + | |
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
Lines changed: 18 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
| 20 | + | |
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
27 | 27 | | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
28 | 32 | | |
29 | 33 | | |
30 | 34 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
| 20 | + | |
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
38 | 38 | | |
39 | 39 | | |
40 | 40 | | |
41 | | - | |
| 41 | + | |
42 | 42 | | |
43 | 43 | | |
44 | | - | |
| 44 | + | |
45 | 45 | | |
46 | 46 | | |
47 | 47 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
50 | 50 | | |
51 | 51 | | |
52 | 52 | | |
53 | | - | |
| 53 | + | |
54 | 54 | | |
55 | 55 | | |
56 | 56 | | |
| |||
68 | 68 | | |
69 | 69 | | |
70 | 70 | | |
71 | | - | |
| 71 | + | |
72 | 72 | | |
73 | 73 | | |
74 | 74 | | |
0 commit comments