Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Dapper
提交
d701fd03
D
Dapper
项目概览
int
/
Dapper
11 个月 前同步成功
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Dapper
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d701fd03
编写于
5月 10, 2011
作者:
S
simon.cropp
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
use typehandle instead of type
remove redundant use of identity
上级
6a382e1f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
28 addition
and
19 deletion
+28
-19
Dapper/SqlMapper.cs
Dapper/SqlMapper.cs
+28
-19
未找到文件。
Dapper/SqlMapper.cs
浏览文件 @
d701fd03
...
...
@@ -195,13 +195,17 @@ private static IEnumerable<T> QueryInternal<T>(this IDbConnection cnn, string sq
{
using
(
var
reader
=
cmd
.
ExecuteReader
())
{
Func
<
IDataReader
,
T
>
deserializer
;
if
(
info
.
Deserializer
==
null
)
{
info
.
Deserializer
=
GetDeserializer
<
T
>(
identity
,
reader
);
info
.
Deserializer
=
deserializer
=
GetDeserializer
<
T
>(
reader
);
queryCache
[
identity
]
=
info
;
}
else
{
deserializer
=
(
Func
<
IDataReader
,
T
>)
info
.
Deserializer
;
}
var
deserializer
=
(
Func
<
IDataReader
,
T
>)
info
.
Deserializer
;
while
(
reader
.
Read
())
{
...
...
@@ -283,30 +287,30 @@ class DontMap {}
var
otherDeserializer
=
new
List
<
object
>();
int
split
=
nextSplit
();
info
.
Deserializer
=
GetDeserializer
<
T
>(
identity
,
reader
,
0
,
split
);
info
.
Deserializer
=
GetDeserializer
<
T
>(
reader
,
0
,
split
);
if
(
typeof
(
U
)
!=
typeof
(
DontMap
))
{
var
next
=
nextSplit
();
otherDeserializer
.
Add
(
GetDeserializer
<
U
>(
identity
,
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
otherDeserializer
.
Add
(
GetDeserializer
<
U
>(
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
split
=
next
;
}
if
(
typeof
(
V
)
!=
typeof
(
DontMap
))
{
var
next
=
nextSplit
();
otherDeserializer
.
Add
(
GetDeserializer
<
V
>(
identity
,
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
otherDeserializer
.
Add
(
GetDeserializer
<
V
>(
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
split
=
next
;
}
if
(
typeof
(
Z
)
!=
typeof
(
DontMap
))
{
var
next
=
nextSplit
();
otherDeserializer
.
Add
(
GetDeserializer
<
Z
>(
identity
,
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
otherDeserializer
.
Add
(
GetDeserializer
<
Z
>(
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
split
=
next
;
}
if
(
typeof
(
X
)
!=
typeof
(
DontMap
))
{
var
next
=
nextSplit
();
otherDeserializer
.
Add
(
GetDeserializer
<
X
>(
identity
,
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
otherDeserializer
.
Add
(
GetDeserializer
<
X
>(
reader
,
split
,
next
-
split
,
returnNullIfFirstMissing
:
true
));
}
info
.
OtherDeserializers
=
otherDeserializer
.
ToArray
();
...
...
@@ -382,27 +386,33 @@ class DontMap {}
private
static
CacheInfo
GetCacheInfo
(
object
param
,
Identity
identity
)
{
CacheInfo
info
;
if
(
!
queryCache
.
TryGetValue
(
identity
,
out
info
))
if
(
queryCache
.
TryGetValue
(
identity
,
out
info
))
{
info
=
new
CacheInfo
();
if
(
param
!=
null
)
{
info
.
ParamReader
=
CreateParamInfoGenerator
(
param
.
GetType
());
}
return
info
;
}
info
=
new
CacheInfo
();
if
(
param
!=
null
)
{
info
.
ParamReader
=
CreateParamInfoGenerator
(
param
.
GetType
());
}
return
info
;
}
private
static
Func
<
IDataReader
,
T
>
GetDeserializer
<
T
>(
Identity
identity
,
IDataReader
reader
,
int
startBound
=
0
,
int
length
=
-
1
,
bool
returnNullIfFirstMissing
=
false
)
static
RuntimeTypeHandle
objectTypeHandle
=
typeof
(
object
).
TypeHandle
;
static
RuntimeTypeHandle
expandoTypeHandle
=
typeof
(
ExpandoObject
).
TypeHandle
;
static
RuntimeTypeHandle
stringTypeHandle
=
typeof
(
string
).
TypeHandle
;
private
static
Func
<
IDataReader
,
T
>
GetDeserializer
<
T
>(
IDataReader
reader
,
int
startBound
=
0
,
int
length
=
-
1
,
bool
returnNullIfFirstMissing
=
false
)
{
// dynamic is passed in as Object ... by c# design
if
(
typeof
(
T
)
==
typeof
(
object
)
||
typeof
(
T
)
==
typeof
(
ExpandoObject
))
var
tHandle
=
typeof
(
T
).
TypeHandle
;
if
(
tHandle
.
Equals
(
objectTypeHandle
)
||
tHandle
.
Equals
(
expandoTypeHandle
))
{
return
GetDynamicDeserializer
<
T
>(
reader
,
startBound
,
length
,
returnNullIfFirstMissing
);
}
if
(
typeof
(
T
).
IsClass
&&
typeof
(
T
)
!=
typeof
(
string
))
if
(
typeof
(
T
).
IsClass
&&
!
tHandle
.
Equals
(
stringTypeHandle
))
{
return
GetClassDeserializer
<
T
>(
reader
,
startBound
,
length
,
returnNullIfFirstMissing
:
returnNullIfFirstMissing
);
return
GetClassDeserializer
<
T
>(
reader
,
startBound
,
length
,
returnNullIfFirstMissing
);
}
return
GetStructDeserializer
<
T
>();
...
...
@@ -784,8 +794,7 @@ public IEnumerable<T> Read<T>()
{
if
(
reader
==
null
)
throw
new
ObjectDisposedException
(
GetType
().
Name
);
if
(
consumed
)
throw
new
InvalidOperationException
(
"Each grid can only be iterated once"
);
var
identity
=
new
Identity
(
sql
,
connection
,
typeof
(
T
),
null
);
var
deserializer
=
GetDeserializer
<
T
>(
identity
,
reader
);
var
deserializer
=
GetDeserializer
<
T
>(
reader
);
consumed
=
true
;
return
ReadDeferred
(
gridIndex
,
deserializer
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录