public static Task<IReadOnlyList<VCard>> DeserializeAsync(
Func<CancellationToken, Task<Stream>> factory,
AnsiFilter filter,
CancellationToken token = default
)
Public Shared Function DeserializeAsync (
factory As Func(Of CancellationToken, Task(Of Stream)),
filter As AnsiFilter,
Optional token As CancellationToken = Nothing
) As Task(Of IReadOnlyList(Of VCard))
public:
static Task<IReadOnlyList<VCard^>^>^ DeserializeAsync(
Func<CancellationToken, Task<Stream^>^>^ factory,
AnsiFilter^ filter,
CancellationToken token = CancellationToken()
)
static member DeserializeAsync :
factory : Func<CancellationToken, Task<Stream>> *
filter : AnsiFilter *
?token : CancellationToken
(* Defaults:
let _token = defaultArg token new CancellationToken()
*)
-> Task<IReadOnlyList<VCard>>
AnsiFilter only recognizes one Encoding per Stream. This means that if a Stream contains VCF data with different Encodings, decoding errors may occur.
Any Streams that are used within the method will be closed when the method completes.
using FolkerKinzel.VCards;
namespace Examples;
public static class WebExample
{
private const string URI =
"https://raw.githubusercontent.com/FolkerKinzel/VCards/master/src/Examples/AnsiFilterExamples/German.vcf";
private static readonly HttpClient _client = new();
public static async Task AsyncExample()
{
using var cts = new CancellationTokenSource();
IReadOnlyList<VCard> vc = await Vcf.DeserializeAsync(t => _client.GetStreamAsync(URI, t),
new AnsiFilter(),
cts.Token);
Console.WriteLine(vc[0]);
}
public static void SynchronousExample()
{
using HttpResponseMessage response =
_client.Send(new HttpRequestMessage(HttpMethod.Get, URI));
IReadOnlyList<VCard> vc = Vcf.Deserialize(() => response.Content.ReadAsStream(),
new AnsiFilter());
Console.WriteLine(vc[0]);
}
}
/*
Console Output:
Version: 2.1
DisplayNames: Sören Täve Nüßlebaum
NameViews:
FamilyNames: Nüßlebaum
GivenNames: Sören
AdditionalNames: Täve
[Label: Mößlitz]
[CharSet: Windows-1252]
Addresses: Locality: Mößlitz
*/
ArgumentNullException | factory or filter is null. |
ArgumentException | The Stream that factory returns asynchronously doesn't support reading. |
ObjectDisposedException | factory returns a closed stream. |
IOException | The method could not read from the Stream. |