Mercurial > pub > bltoolkit
view Source/Data/Linq/SqlFunctionAttribute.cs @ 2:79a04c6442bf
file name case fix
author | cin |
---|---|
date | Fri, 22 Aug 2014 13:41:57 +0400 |
parents | f990fcb411a9 |
children |
line wrap: on
line source
using System; using System.Linq; using System.Reflection; namespace BLToolkit.Data.Linq { using Data.Sql; using Reflection; [SerializableAttribute] [AttributeUsageAttribute(AttributeTargets.Method | AttributeTargets.Property, AllowMultiple = true, Inherited = false)] public class SqlFunctionAttribute : Attribute { public SqlFunctionAttribute() { } public SqlFunctionAttribute(string name) { Name = name; } public SqlFunctionAttribute(string name, params int[] argIndices) { Name = name; ArgIndices = argIndices; } public SqlFunctionAttribute(string sqlProvider, string name) { SqlProvider = sqlProvider; Name = name; } public SqlFunctionAttribute(string sqlProvider, string name, params int[] argIndices) { SqlProvider = sqlProvider; Name = name; ArgIndices = argIndices; } public string SqlProvider { get; set; } public string Name { get; set; } public bool ServerSideOnly { get; set; } public bool PreferServerSide { get; set; } public int[] ArgIndices { get; set; } protected ISqlExpression[] ConvertArgs(MemberInfo member, ISqlExpression[] args) { if (member is MethodInfo) { var method = (MethodInfo)member; if (method.DeclaringType.IsGenericType) args = args.Concat(method.DeclaringType.GetGenericArguments().Select(t => (ISqlExpression)SqlDataType.GetDataType(t))).ToArray(); if (method.IsGenericMethod) args = args.Concat(method.GetGenericArguments().Select(t => (ISqlExpression)SqlDataType.GetDataType(t))).ToArray(); } if (ArgIndices != null) { var idxs = new ISqlExpression[ArgIndices.Length]; for (var i = 0; i < ArgIndices.Length; i++) idxs[i] = args[ArgIndices[i]]; return idxs; } return args; } public virtual ISqlExpression GetExpression(MemberInfo member, params ISqlExpression[] args) { return new SqlFunction(TypeHelper.GetMemberType(member), Name ?? member.Name, ConvertArgs(member, args)); } } }