forked from npgsql/npgsql
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLQueryHandler.cs
More file actions
103 lines (78 loc) · 4.07 KB
/
LQueryHandler.cs
File metadata and controls
103 lines (78 loc) · 4.07 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
using System;
using System.IO;
using System.Threading;
using System.Threading.Tasks;
using Npgsql.BackendMessages;
using Npgsql.PostgresTypes;
using Npgsql.TypeHandling;
using Npgsql.TypeMapping;
using NpgsqlTypes;
namespace Npgsql.TypeHandlers
{
#pragma warning disable CS1591 // Missing XML comment for publicly visible type or member
[TypeMapping("lquery", NpgsqlDbType.LQuery)]
class LQueryHandlerFactory : NpgsqlTypeHandlerFactory<string>
{
public override NpgsqlTypeHandler<string> Create(PostgresType postgresType, NpgsqlConnection conn)
=> new LQueryHandler(postgresType, conn);
}
/// <summary>
/// LQuery binary encoding is a simple UTF8 string, but prepended with a version number.
/// </summary>
public class LQueryHandler : TextHandler
{
/// <summary>
/// Prepended to the string in the wire encoding
/// </summary>
const byte LQueryProtocolVersion = 1;
internal override bool PreferTextWrite => false;
protected internal LQueryHandler(PostgresType postgresType, NpgsqlConnection connection)
: base(postgresType, connection) {}
#region Write
public override int ValidateAndGetLength(string value, ref NpgsqlLengthCache? lengthCache, NpgsqlParameter? parameter) =>
base.ValidateAndGetLength(value, ref lengthCache, parameter) + 1;
public override int ValidateAndGetLength(char[] value, ref NpgsqlLengthCache? lengthCache, NpgsqlParameter? parameter) =>
base.ValidateAndGetLength(value, ref lengthCache, parameter) + 1;
public override int ValidateAndGetLength(ArraySegment<char> value, ref NpgsqlLengthCache? lengthCache, NpgsqlParameter? parameter) =>
base.ValidateAndGetLength(value, ref lengthCache, parameter) + 1;
public override async Task Write(string value, NpgsqlWriteBuffer buf, NpgsqlLengthCache? lengthCache, NpgsqlParameter? parameter, bool async, CancellationToken cancellationToken = default)
{
if (buf.WriteSpaceLeft < 1)
await buf.Flush(async, cancellationToken);
buf.WriteByte(LQueryProtocolVersion);
await base.Write(value, buf, lengthCache, parameter, async, cancellationToken);
}
public override async Task Write(char[] value, NpgsqlWriteBuffer buf, NpgsqlLengthCache? lengthCache, NpgsqlParameter? parameter, bool async, CancellationToken cancellationToken = default)
{
if (buf.WriteSpaceLeft < 1)
await buf.Flush(async, cancellationToken);
buf.WriteByte(LQueryProtocolVersion);
await base.Write(value, buf, lengthCache, parameter, async, cancellationToken);
}
public override async Task Write(ArraySegment<char> value, NpgsqlWriteBuffer buf, NpgsqlLengthCache? lengthCache, NpgsqlParameter? parameter, bool async, CancellationToken cancellationToken = default)
{
if (buf.WriteSpaceLeft < 1)
await buf.Flush(async, cancellationToken);
buf.WriteByte(LQueryProtocolVersion);
await base.Write(value, buf, lengthCache, parameter, async, cancellationToken);
}
#endregion
#region Read
public override async ValueTask<string> Read(NpgsqlReadBuffer buf, int len, bool async, FieldDescription? fieldDescription = null)
{
await buf.Ensure(1, async);
var version = buf.ReadByte();
if (version != LQueryProtocolVersion)
throw new NotSupportedException($"Don't know how to decode lquery with wire format {version}, your connection is now broken");
return await base.Read(buf, len - 1, async, fieldDescription);
}
#endregion
public override TextReader GetTextReader(Stream stream)
{
var version = stream.ReadByte();
if (version != LQueryProtocolVersion)
throw new NpgsqlException($"Don't know how to decode lquery with wire format {version}, your connection is now broken");
return base.GetTextReader(stream);
}
}
}