ktsu.ToStringJsonConverter 1.2.4

Prefix Reserved
dotnet add package ktsu.ToStringJsonConverter --version 1.2.4
                    
NuGet\Install-Package ktsu.ToStringJsonConverter -Version 1.2.4
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ktsu.ToStringJsonConverter" Version="1.2.4" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="ktsu.ToStringJsonConverter" Version="1.2.4" />
                    
Directory.Packages.props
<PackageReference Include="ktsu.ToStringJsonConverter" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add ktsu.ToStringJsonConverter --version 1.2.4
                    
#r "nuget: ktsu.ToStringJsonConverter, 1.2.4"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package ktsu.ToStringJsonConverter@1.2.4
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=ktsu.ToStringJsonConverter&version=1.2.4
                    
Install as a Cake Addin
#tool nuget:?package=ktsu.ToStringJsonConverter&version=1.2.4
                    
Install as a Cake Tool

ktsu.ToStringJsonConverter

A JSON converter factory that serializes objects using their ToString and FromString methods.

License NuGet NuGet Downloads Build Status GitHub Stars

Introduction

ToStringJsonConverter is a JSON converter factory for System.Text.Json that simplifies serialization and deserialization of custom types by leveraging their ToString and FromString methods. This approach is particularly useful for value types, strong types, and any other types where a string representation makes logical sense.

Features

  • Automatic Type Detection: Automatically identifies types with compatible FromString methods.
  • String-Based Serialization: Converts objects to and from JSON using their string representation.
  • Property Name Support: Works with both JSON values and property names.
  • Reflection Optimization: Uses cached reflection for improved performance.
  • Generic Method Support: Handles both generic and non-generic FromString methods.

Installation

Package Manager Console

Install-Package ktsu.ToStringJsonConverter

.NET CLI

dotnet add package ktsu.ToStringJsonConverter

Package Reference

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

Usage Examples

Basic Example

using System.Text.Json;
using ktsu.ToStringJsonConverter;

// Configure the converter in your JsonSerializerOptions
var options = new JsonSerializerOptions();
options.Converters.Add(new ToStringJsonConverterFactory());

// Example custom type with ToString and FromString
public class CustomId
{
    public string Value { get; set; }
    
    public static CustomId FromString(string value) => new() { Value = value };
    
    public override string ToString() => Value;
}

// Serialization
var id = new CustomId { Value = "12345" };
string json = JsonSerializer.Serialize(id, options);
// json is now: "12345"

// Deserialization
CustomId deserialized = JsonSerializer.Deserialize<CustomId>(json, options);
// deserialized.Value is now: "12345"

Integration with Other Converters

using System.Text.Json;
using System.Text.Json.Serialization;
using ktsu.ToStringJsonConverter;

var options = new JsonSerializerOptions
{
    WriteIndented = true,
    PropertyNamingPolicy = JsonNamingPolicy.CamelCase,
    Converters =
    {
        new ToStringJsonConverterFactory(),
        new JsonStringEnumConverter()
    }
};

// Now both enum values and custom types with FromString will be handled appropriately

Advanced Usage

Working with Collections of Custom Types

using System.Text.Json;
using ktsu.ToStringJsonConverter;

// Setup serializer options with the converter
var options = new JsonSerializerOptions();
options.Converters.Add(new ToStringJsonConverterFactory());

// A collection of custom types
List<CustomId> ids = new()
{
    new CustomId { Value = "A001" },
    new CustomId { Value = "B002" },
    new CustomId { Value = "C003" }
};

// Serialize the collection
string json = JsonSerializer.Serialize(ids, options);
// json is now: ["A001","B002","C003"]

// Deserialize back to a collection
List<CustomId> deserializedIds = JsonSerializer.Deserialize<List<CustomId>>(json, options);

Using with Dictionaries as Keys

// Custom type can be used as dictionary keys
var dictionary = new Dictionary<CustomId, string>
{
    { new CustomId { Value = "key1" }, "value1" },
    { new CustomId { Value = "key2" }, "value2" }
};

string json = JsonSerializer.Serialize(dictionary, options);
// Serializes as a dictionary with string keys

var deserialized = JsonSerializer.Deserialize<Dictionary<CustomId, string>>(json, options);
// Keys are properly deserialized back to CustomId objects

API Reference

ToStringJsonConverterFactory

The primary class for integrating with System.Text.Json serialization.

Methods
Name Return Type Description
CanConvert(Type typeToConvert) bool Determines if a type can be converted by checking for a static FromString method
CreateConverter(Type typeToConvert, JsonSerializerOptions options) JsonConverter Creates a type-specific converter instance

Compatibility Requirements

For a type to work with ToStringJsonConverter, it must meet these requirements:

  1. Have a public static FromString(string) method that returns an instance of the type
  2. Override ToString() to provide a string representation that can be reversed by FromString

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.

License

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

Product Compatible and additional computed target framework versions.
.NET 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 was computed.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on ktsu.ToStringJsonConverter:

Package Downloads
ktsu.AppDataStorage

Application data management library using JSON serialization to save and load data in the user's app data folder.

ktsu.Schema

Schema

ktsu.PkmnDB

PkmnDB

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.2.4 261 5/21/2025
1.2.4-pre.17 111 5/20/2025
1.2.4-pre.15 73 5/17/2025
1.2.4-pre.14 133 5/16/2025
1.2.4-pre.13 200 5/15/2025
1.2.4-pre.12 207 5/14/2025
1.2.4-pre.11 200 5/13/2025
1.2.4-pre.10 236 5/12/2025
1.2.4-pre.9 164 5/11/2025
1.2.4-pre.8 107 5/10/2025
1.2.4-pre.7 48 5/9/2025
1.2.4-pre.6 125 5/8/2025
1.2.4-pre.5 121 5/7/2025
1.2.4-pre.4 122 5/6/2025
1.2.4-pre.3 114 5/5/2025
1.2.4-pre.2 125 5/4/2025
1.2.4-pre.1 118 5/4/2025
1.2.3 2,796 5/4/2025
1.2.3-pre.1 51 4/26/2025
1.2.2 585 4/25/2025
1.2.2-pre.1 124 4/4/2025
1.2.1 698 3/30/2025
1.2.0 382 3/30/2025
1.1.1-pre.3 80 3/29/2025
1.1.1-pre.2 461 3/25/2025
1.1.1-pre.1 77 2/18/2025
1.1.0 954 2/17/2025
1.0.49-pre.3 86 2/6/2025
1.0.49-pre.2 68 2/5/2025
1.0.49-pre.1 69 2/5/2025
1.0.48 2,484 12/27/2024
1.0.48-pre.30 71 2/4/2025
1.0.48-pre.29 68 2/3/2025
1.0.48-pre.28 77 2/1/2025
1.0.48-pre.27 68 1/30/2025
1.0.48-pre.26 66 1/28/2025
1.0.48-pre.25 64 1/26/2025
1.0.48-pre.24 67 1/24/2025
1.0.48-pre.23 70 1/22/2025
1.0.48-pre.22 64 1/20/2025
1.0.48-pre.21 61 1/18/2025
1.0.48-pre.20 58 1/16/2025
1.0.48-pre.19 51 1/14/2025
1.0.48-pre.18 58 1/13/2025
1.0.48-pre.17 66 1/11/2025
1.0.48-pre.16 61 1/10/2025
1.0.48-pre.15 63 1/10/2025
1.0.48-pre.14 54 1/8/2025
1.0.48-pre.13 72 1/7/2025
1.0.48-pre.12 74 1/5/2025
1.0.48-pre.11 93 1/3/2025
1.0.48-pre.10 69 1/3/2025
1.0.48-pre.9 73 1/3/2025
1.0.48-pre.8 75 1/3/2025
1.0.48-pre.7 68 1/2/2025
1.0.48-pre.6 94 12/31/2024
1.0.48-pre.5 72 12/30/2024
1.0.48-pre.4 75 12/29/2024
1.0.48-pre.3 63 12/28/2024
1.0.48-pre.2 65 12/27/2024
1.0.48-pre.1 68 12/27/2024
1.0.47-pre.1 72 12/27/2024
1.0.46 290 12/26/2024
1.0.45 105 12/26/2024
1.0.44 99 12/26/2024
1.0.43 96 12/26/2024
1.0.42 106 12/26/2024
1.0.41 120 12/26/2024
1.0.40 98 12/26/2024
1.0.39 105 12/25/2024
1.0.38 255 12/23/2024
1.0.37 262 12/23/2024
1.0.36 96 12/23/2024
1.0.35 128 12/23/2024
1.0.34 326 12/19/2024
1.0.33 246 12/16/2024
1.0.32 336 12/6/2024
1.0.31 276 12/5/2024
1.0.30 153 12/4/2024
1.0.29 254 12/2/2024
1.0.28 119 12/2/2024
1.0.27 140 12/2/2024
1.0.26 185 12/1/2024
1.0.25 184 12/1/2024
1.0.24 155 11/30/2024
1.0.23 119 11/29/2024
1.0.22 205 11/27/2024
1.0.21 179 11/26/2024
1.0.20 198 11/20/2024
1.0.19 314 11/15/2024
1.0.18 187 11/14/2024
1.0.17 175 11/13/2024
1.0.16 423 11/4/2024
1.0.15 180 11/1/2024
1.0.14 594 10/17/2024
1.0.13 400 10/7/2024
1.0.12 158 10/4/2024
1.0.11 321 9/23/2024
1.0.10 142 9/20/2024
1.0.10-pre.1 57 12/27/2024
1.0.9 163 9/19/2024
1.0.8 167 9/19/2024
1.0.7 114 9/19/2024
1.0.6 142 9/19/2024
1.0.5 123 9/18/2024
1.0.4 117 9/18/2024
1.0.3 229 9/18/2024
1.0.2 156 9/18/2024
1.0.1 224 9/14/2024
1.0.0 125 9/14/2024

## v1.2.4

Initial release or repository with no prior history.