mirror of
https://github.com/OrchardCMS/Orchard.git
synced 2025-04-05 21:01:35 +08:00
Addinf fluentnhibernate patches.
--HG-- branch : 1.x
This commit is contained in:
parent
6a88f44e73
commit
a6bee4cdab
@ -0,0 +1,84 @@
|
||||
# HG changeset patch
|
||||
# User Andre Rodrigues <andrerod@microsoft.com>
|
||||
# Date 1305755030 25200
|
||||
# Node ID 9cd8564ec960ed8b634f87249da62a69b506b60f
|
||||
# Parent 82d19d966b63b14bc6b7e1d76404c0fb0aacf4e0
|
||||
Exposing References method to avoid the usage of propertyinfo.
|
||||
|
||||
diff -r 82d19d966b63 -r 9cd8564ec960 src/FluentNHibernate/Mapping/ClasslikeMapBase.cs
|
||||
--- a/src/FluentNHibernate/Mapping/ClasslikeMapBase.cs Wed May 18 14:42:42 2011 -0700
|
||||
+++ b/src/FluentNHibernate/Mapping/ClasslikeMapBase.cs Wed May 18 14:43:50 2011 -0700
|
||||
@@ -64,7 +64,11 @@
|
||||
|
||||
protected virtual ManyToOnePart<TOther> References<TOther>(PropertyInfo property, string columnName)
|
||||
{
|
||||
- var part = new ManyToOnePart<TOther>(EntityType, property);
|
||||
+ return References<TOther>(property.DeclaringType, property.Name, columnName);
|
||||
+ }
|
||||
+
|
||||
+ public ManyToOnePart<TOther> References<TOther>(Type declaringType, string propertyName, string columnName) {
|
||||
+ var part = new ManyToOnePart<TOther>(EntityType, propertyName, declaringType.Name);
|
||||
|
||||
if (columnName != null)
|
||||
part.Column(columnName);
|
||||
diff -r 82d19d966b63 -r 9cd8564ec960 src/FluentNHibernate/Mapping/CompositeElementPart.cs
|
||||
--- a/src/FluentNHibernate/Mapping/CompositeElementPart.cs Wed May 18 14:42:42 2011 -0700
|
||||
+++ b/src/FluentNHibernate/Mapping/CompositeElementPart.cs Wed May 18 14:43:50 2011 -0700
|
||||
@@ -59,7 +59,7 @@
|
||||
|
||||
protected virtual ManyToOnePart<TOther> References<TOther>(PropertyInfo property, string columnName)
|
||||
{
|
||||
- var part = new ManyToOnePart<TOther>(typeof(T), property);
|
||||
+ var part = new ManyToOnePart<TOther>(typeof(T), property.Name, property.DeclaringType.Name);
|
||||
|
||||
if (columnName != null)
|
||||
part.Column(columnName);
|
||||
diff -r 82d19d966b63 -r 9cd8564ec960 src/FluentNHibernate/Mapping/ManyToOnePart.cs
|
||||
--- a/src/FluentNHibernate/Mapping/ManyToOnePart.cs Wed May 18 14:42:42 2011 -0700
|
||||
+++ b/src/FluentNHibernate/Mapping/ManyToOnePart.cs Wed May 18 14:43:50 2011 -0700
|
||||
@@ -20,12 +20,14 @@
|
||||
private readonly AttributeStore<ManyToOneMapping> attributes = new AttributeStore<ManyToOneMapping>();
|
||||
private readonly AttributeStore<ColumnMapping> columnAttributes = new AttributeStore<ColumnMapping>();
|
||||
private readonly Type entity;
|
||||
- private readonly PropertyInfo property;
|
||||
+ private readonly string name;
|
||||
+ private readonly string declaringTypeName;
|
||||
|
||||
- public ManyToOnePart(Type entity, PropertyInfo property)
|
||||
+ public ManyToOnePart(Type entity, string name, string declaringTypeName)
|
||||
{
|
||||
this.entity = entity;
|
||||
- this.property = property;
|
||||
+ this.name = name;
|
||||
+ this.declaringTypeName = declaringTypeName;
|
||||
access = new AccessStrategyBuilder<ManyToOnePart<TOther>>(this, value => attributes.Set(x => x.Access, value));
|
||||
fetch = new FetchTypeExpression<ManyToOnePart<TOther>>(this, value => attributes.Set(x => x.Fetch, value));
|
||||
cascade = new CascadeExpression<ManyToOnePart<TOther>>(this, value => attributes.Set(x => x.Cascade, value));
|
||||
@@ -37,16 +39,15 @@
|
||||
var mapping = new ManyToOneMapping(attributes.CloneInner());
|
||||
|
||||
mapping.ContainingEntityType = entity;
|
||||
- mapping.PropertyInfo = property;
|
||||
|
||||
if (!mapping.IsSpecified("Name"))
|
||||
- mapping.Name = property.Name;
|
||||
+ mapping.Name = name;
|
||||
|
||||
if (!mapping.IsSpecified("Class"))
|
||||
mapping.SetDefaultValue(x => x.Class, new TypeReference(typeof(TOther)));
|
||||
|
||||
if (columns.Count == 0)
|
||||
- mapping.AddDefaultColumn(CreateColumn(property.Name + "_id"));
|
||||
+ mapping.AddDefaultColumn(CreateColumn(name + "_id"));
|
||||
|
||||
foreach (var column in columns)
|
||||
{
|
||||
@@ -124,7 +125,7 @@
|
||||
|
||||
public ManyToOnePart<TOther> ForeignKey()
|
||||
{
|
||||
- return ForeignKey(string.Format("FK_{0}To{1}", property.DeclaringType.Name, property.Name));
|
||||
+ return ForeignKey(string.Format("FK_{0}To{1}", declaringTypeName, name));
|
||||
}
|
||||
|
||||
public ManyToOnePart<TOther> ForeignKey(string foreignKeyName)
|
@ -0,0 +1,21 @@
|
||||
# HG changeset patch
|
||||
# User Andre Rodrigues <andrerod@microsoft.com>
|
||||
# Date 1305755041 25200
|
||||
# Node ID 48d2b0560a4196a96e906a218208b69ff9db25bd
|
||||
# Parent 9cd8564ec960ed8b634f87249da62a69b506b60f
|
||||
Making GenericEnumMapper Serializable.
|
||||
|
||||
diff -r 9cd8564ec960 -r 48d2b0560a41 src/FluentNHibernate/Mapping/GenericEnumMapper.cs
|
||||
--- a/src/FluentNHibernate/Mapping/GenericEnumMapper.cs Wed May 18 14:43:50 2011 -0700
|
||||
+++ b/src/FluentNHibernate/Mapping/GenericEnumMapper.cs Wed May 18 14:44:01 2011 -0700
|
||||
@@ -1,7 +1,9 @@
|
||||
-using NHibernate.Type;
|
||||
+using System;
|
||||
+using NHibernate.Type;
|
||||
|
||||
namespace FluentNHibernate.Mapping
|
||||
{
|
||||
+ [Serializable]
|
||||
public class GenericEnumMapper<TEnum> : EnumStringType
|
||||
{
|
||||
public GenericEnumMapper()
|
Loading…
Reference in New Issue
Block a user