-
Notifications
You must be signed in to change notification settings - Fork 4.5k
/
DatasetStorageFormat.Serialization.cs
121 lines (106 loc) · 5.28 KB
/
DatasetStorageFormat.Serialization.cs
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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// <auto-generated/>
#nullable disable
using System;
using System.ClientModel.Primitives;
using System.Text.Json;
using Azure.Core;
namespace Azure.ResourceManager.DataFactory.Models
{
[PersistableModelProxy(typeof(UnknownDatasetStorageFormat))]
public partial class DatasetStorageFormat : IUtf8JsonSerializable, IJsonModel<DatasetStorageFormat>
{
void IUtf8JsonSerializable.Write(Utf8JsonWriter writer) => ((IJsonModel<DatasetStorageFormat>)this).Write(writer, ModelSerializationExtensions.WireOptions);
void IJsonModel<DatasetStorageFormat>.Write(Utf8JsonWriter writer, ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<DatasetStorageFormat>)this).GetFormatFromOptions(options) : options.Format;
if (format != "J")
{
throw new FormatException($"The model {nameof(DatasetStorageFormat)} does not support writing '{format}' format.");
}
writer.WriteStartObject();
writer.WritePropertyName("type"u8);
writer.WriteStringValue(DatasetStorageFormatType);
if (Optional.IsDefined(Serializer))
{
writer.WritePropertyName("serializer"u8);
JsonSerializer.Serialize(writer, Serializer);
}
if (Optional.IsDefined(Deserializer))
{
writer.WritePropertyName("deserializer"u8);
JsonSerializer.Serialize(writer, Deserializer);
}
foreach (var item in AdditionalProperties)
{
writer.WritePropertyName(item.Key);
#if NET6_0_OR_GREATER
writer.WriteRawValue(item.Value);
#else
using (JsonDocument document = JsonDocument.Parse(item.Value))
{
JsonSerializer.Serialize(writer, document.RootElement);
}
#endif
}
writer.WriteEndObject();
}
DatasetStorageFormat IJsonModel<DatasetStorageFormat>.Create(ref Utf8JsonReader reader, ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<DatasetStorageFormat>)this).GetFormatFromOptions(options) : options.Format;
if (format != "J")
{
throw new FormatException($"The model {nameof(DatasetStorageFormat)} does not support reading '{format}' format.");
}
using JsonDocument document = JsonDocument.ParseValue(ref reader);
return DeserializeDatasetStorageFormat(document.RootElement, options);
}
internal static DatasetStorageFormat DeserializeDatasetStorageFormat(JsonElement element, ModelReaderWriterOptions options = null)
{
options ??= ModelSerializationExtensions.WireOptions;
if (element.ValueKind == JsonValueKind.Null)
{
return null;
}
if (element.TryGetProperty("type", out JsonElement discriminator))
{
switch (discriminator.GetString())
{
case "AvroFormat": return DatasetAvroFormat.DeserializeDatasetAvroFormat(element, options);
case "JsonFormat": return DatasetJsonFormat.DeserializeDatasetJsonFormat(element, options);
case "OrcFormat": return DatasetOrcFormat.DeserializeDatasetOrcFormat(element, options);
case "ParquetFormat": return DatasetParquetFormat.DeserializeDatasetParquetFormat(element, options);
case "TextFormat": return DatasetTextFormat.DeserializeDatasetTextFormat(element, options);
}
}
return UnknownDatasetStorageFormat.DeserializeUnknownDatasetStorageFormat(element, options);
}
BinaryData IPersistableModel<DatasetStorageFormat>.Write(ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<DatasetStorageFormat>)this).GetFormatFromOptions(options) : options.Format;
switch (format)
{
case "J":
return ModelReaderWriter.Write(this, options);
default:
throw new FormatException($"The model {nameof(DatasetStorageFormat)} does not support writing '{options.Format}' format.");
}
}
DatasetStorageFormat IPersistableModel<DatasetStorageFormat>.Create(BinaryData data, ModelReaderWriterOptions options)
{
var format = options.Format == "W" ? ((IPersistableModel<DatasetStorageFormat>)this).GetFormatFromOptions(options) : options.Format;
switch (format)
{
case "J":
{
using JsonDocument document = JsonDocument.Parse(data);
return DeserializeDatasetStorageFormat(document.RootElement, options);
}
default:
throw new FormatException($"The model {nameof(DatasetStorageFormat)} does not support reading '{options.Format}' format.");
}
}
string IPersistableModel<DatasetStorageFormat>.GetFormatFromOptions(ModelReaderWriterOptions options) => "J";
}
}