UtilityVerse.Copy
0.3.0
See the version list below for details.
dotnet add package UtilityVerse.Copy --version 0.3.0
NuGet\Install-Package UtilityVerse.Copy -Version 0.3.0
<PackageReference Include="UtilityVerse.Copy" Version="0.3.0" />
<PackageVersion Include="UtilityVerse.Copy" Version="0.3.0" />
<PackageReference Include="UtilityVerse.Copy" />
paket add UtilityVerse.Copy --version 0.3.0
#r "nuget: UtilityVerse.Copy, 0.3.0"
#:package UtilityVerse.Copy@0.3.0
#addin nuget:?package=UtilityVerse.Copy&version=0.3.0
#tool nuget:?package=UtilityVerse.Copy&version=0.3.0
π¦ UtilityVerse.Copy β Source Generator for DeepCopy and ShallowCopy in C#
π UtilityVerse.Copy is a Roslyn-based source generator that automatically creates DeepCopy()
and ShallowCopy()
methods for your models. Eliminate repetitive boilerplate and enjoy clean, maintainable code with zero runtime dependencies.
β¨ Features
- β
Automatically generates
DeepCopy()
and/orShallowCopy()
methods at compile-time - β No runtime overhead β it's all generated in the background by Roslyn
- β
Supports both
[Attribute]
-based andinterface
-based opt-in mechanisms - β Works great for DTOs, ViewModels, and plain C# objects
- β Support for common collection types, arrays, tuples, and more
> Give it a star if you like the project. π π π
π¦ Installation
Install the NuGet package:
dotnet add package UtilityVerse.Copy
π οΈ How It Works
Important: Your classes must be marked
partial
for the generator to emit code successfully.
β Option 1: Use Attributes
Apply [ShallowCopy]
or [DeepCopy]
to your class or struct:
using UtilityVerse.Copy;
[ShallowCopy]
public partial class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
This generates a ShallowCopy()
method at compile-time:
public Person ShallowCopy()
{
return (Person)this.MemberWiseClone();
}
For deep copy:
using UtilityVerse.Copy;
[DeepCopy]
public partial class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
Generates a deep recursive DeepCopy()
method that copies nested references and collections.
public Person DeepCopy()
{
return new Person
{
Name = this.Name,
Age = this.Age
};
}
β Option 2: Use Marker Interfaces
Prefer no attributes? Just implement the marker interfaces:
using UtilityVerse.Copy;
public partial class Person : IShallowCopy
{
public string Name { get; set; }
public int Age { get; set; }
}
using UtilityVerse.Copy;
public partial class Person : IDeepCopy
{
public string Name { get; set; }
public int Age { get; set; }
}
The generator will handle the rest automatically!
π Supported Types
- β Primitives and strings
- β Arrays
- β
Tuples and
ValueTuple
- β
Generic collections:
List<T>
,IEnumerable<T>
,ICollection<T>
,IReadOnlyList<T>
,HashSet<T>
, etc. - β
Dictionary-like collections:
Dictionary<TKey, TValue>
,ConcurrentDictionary
,FrozenDictionary
, etc. - β
Record types, classes, structs (as long as they are
partial
) - β
Nested properties recursively copied in
DeepCopy()
π§ͺ Sample Output
Given this class:
[DeepCopy]
public partial class User
{
public string Name { get; set; }
public List<Address> Addresses { get; set; }
}
Generated deep copy:
public User DeepCopy()
{
return new User
{
Name = this.Name,
Addresses = this.Addresses?.Select(x => x?.DeepCopy()).ToList()
};
}
π Safe and Reliable
- π‘ Partial: Wonβt overwrite your code β generated code lives alongside your class
- π§Ύ Readable: Generated files are emitted to the intermediate folder (obj)
- βοΈ Non-Intrusive: No reflection, no extra dependencies
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 was computed. 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 was computed. 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. |
.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 was computed. |
.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
- Microsoft.CodeAnalysis.CSharp (>= 4.14.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.