Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,20 @@ public void WhenMapPropertiesInTheBaseJumpedClassUsingMemberNameThenMapInInherit
Assert.That(hbmClass.Properties.Select(p => p.Access).All(a => a.StartsWith("field.")), Is.True);
}

[Test]
public void BackfieldAccessPropertyMapping()
{
var mapper = new ModelMapper();
mapper.Class<MyClass>(mc =>
{
mc.Id(x => x.Id, m => m.Access(Accessor.Backfield));
});

HbmMapping mappings = mapper.CompileMappingForAllExplicitlyAddedEntities();
HbmClass hbmClass = mappings.RootClasses[0];
Assert.That(hbmClass.Id.access, Is.EqualTo("backfield"));
}

[Test]
public void WhenMapBagWithWrongElementTypeThenThrows()
{
Expand Down
5 changes: 3 additions & 2 deletions src/NHibernate/Mapping/ByCode/IAccessorPropertyMapper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,13 @@ public enum Accessor
Field,
NoSetter,
ReadOnly,
None
None,
Backfield,
}

public interface IAccessorPropertyMapper
{
void Access(Accessor accessor);
void Access(System.Type accessorType);
}
}
}
5 changes: 4 additions & 1 deletion src/NHibernate/Mapping/ByCode/Impl/AccessorPropertyMapper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,9 @@ public void Access(Accessor accessor)
case Accessor.None:
setAccessor("none");
break;
case Accessor.Backfield:
setAccessor("backfield");
break;
default:
throw new ArgumentOutOfRangeException("accessor");
}
Expand Down Expand Up @@ -136,4 +139,4 @@ private static MemberInfo GetField(System.Type type, string fieldName)
return member;
}
}
}
}