Fixed multithreading safety on JsonMapper

master
Harald Wolff 2022-12-14 14:09:02 +01:00
parent fdef5cc1a7
commit 3e2e2d717c
2 changed files with 27 additions and 13 deletions

View File

@ -9,7 +9,7 @@
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<AssemblyVersion>0.1.0.0</AssemblyVersion>
<FileVersion>0.1.0.0</FileVersion>
<PackageVersion>1.2.1</PackageVersion>
<PackageVersion>1.2.2</PackageVersion>
<TargetFrameworks>net5.0;net6.0</TargetFrameworks>
</PropertyGroup>

View File

@ -54,7 +54,14 @@ namespace ln.json.mapping
Dictionary<Type, JSONMapping> mappings = new Dictionary<Type, JSONMapping>();
public virtual void Add(JSONMapping mapping) => mappings[mapping.TargetType] = mapping;
public virtual void Add(JSONMapping mapping)
{
lock (mappings)
{
mappings[mapping.TargetType] = mapping;
}
}
Dictionary<Type, MappingFactory> mappingFactories = new Dictionary<Type, MappingFactory>();
public virtual void AddMappingFactory(Type targetType, MappingFactory mappingFactory) => mappingFactories.Add(targetType, mappingFactory);
@ -62,14 +69,18 @@ namespace ln.json.mapping
public virtual bool GetOrBuildMapping(Type nativeType, out JSONMapping mapping) => TryGetMapping(nativeType, out mapping) || TryBuildRememberedMapping(nativeType, out mapping);
public virtual bool TryBuildRememberedMapping(Type nativeType,out JSONMapping mapping)
{
lock (mappings)
{
if (TryBuildMapping(nativeType, out mapping))
{
mappings.Add(nativeType, mapping);
return true;
}
return false;
}
}
public virtual bool TryBuildMapping(Type nativeType,out JSONMapping mapping)
{
if (nativeType.IsPrimitive)
@ -118,6 +129,8 @@ namespace ln.json.mapping
}
public virtual bool TryGetMapping(Type nativeType,out JSONMapping mapping)
{
lock (mappings)
{
if (mappings.TryGetValue(nativeType, out mapping))
return true;
@ -130,6 +143,7 @@ namespace ln.json.mapping
return false;
}
}