У меня есть два класса для этого примера, которые являются частичными классами классов классов LINQ-to-SQL.Есть ли другой способ создать контракт для класса модели LINQ-to-SQL?
public partial class Foo
{
public bool IsValid
{
get { return (GetRuleViolations().Count() == 0); }
}
public IEnumerable<RuleViolation> GetRuleViolations()
{
yield break;
}
partial void OnValidate(ChangeAction action)
{
if (!IsValid)
throw new ApplicationException("Rule violations prevent saving");
}
}
public partial class Bar
{
public bool IsValid
{
get { return (GetRuleViolations().Count() == 0); }
}
public IEnumerable<RuleViolation> GetRuleViolations()
{
yield break;
}
partial void OnValidate(ChangeAction action)
{
if (!IsValid)
throw new ApplicationException("Rule violations prevent saving");
}
}
Я хотел бы включить эту функциональность, чтобы удалить избыточную логику. Я попробовал его с интерфейсом IModel, а затем с методами расширения для контрактов, но он сломался с частичным классом.
Я закончил с этим:
public class ModelBase
{
public bool IsValid
{
get
{
return this.GetRuleViolations().Count() == 0;
}
}
public void OnValidate(ChangeAction action)
{
if (!IsValid) throw new ApplicationException("Rule violations prevent saving");
}
public virtual IEnumerable<RuleViolation> GetRuleViolations() { return null; }
}
public partial class Blog : ModelBase
{
partial void OnValidate(ChangeAction action)
{
base.OnValidate(action);
}
public override IEnumerable<RuleViolation> GetRuleViolations()
{
// rules omitted
}
}
Должен ли я сделать это по-другому? Спасибо.
«у вас могут быть разные правила проверки для удаления, чем обновление или вставка», приятно – blu