/// <summary> /// Creates The <see cref="StorageElement"/>. /// An existing file or folder will be preserved and used instead of creating a new one. /// </summary> /// <param name="element">The <see cref="StorageElement"/>.</param> /// <param name="cancellationToken"> /// A <see cref="CancellationToken"/> which can be used to cancel the asynchronous operation. /// </param> /// <remarks> /// Calling this method is equivalent to calling /// <see cref="StorageElement.CreateAsync(bool, CreationCollisionOption, CancellationToken)"/> /// with the <c>recursive: false</c> and <see cref="CreationCollisionOption.UseExisting"/> /// parameters. /// </remarks> /// <exception cref="ArgumentNullException"> /// <paramref name="element"/> is <see langword="null"/>. /// </exception> /// <exception cref="OperationCanceledException"> /// The operation was cancelled via the specified <paramref name="cancellationToken"/>. /// </exception> /// <exception cref="UnauthorizedAccessException"> /// Access to The <see cref="StorageElement"/> is restricted. /// </exception> /// <exception cref="PathTooLongException"> /// The length of The <see cref="StorageElement"/>'s path exceeds the system-defined maximum length. /// </exception> /// <exception cref="IOException"> /// The <see cref="StorageElement"/> is a <see cref="StorageFile"/> (or <see cref="StorageFolder"/>) and a /// conflicting folder (or file) exists at its path. /// /// -or- /// /// An undefined I/O error occured while interacting with the file system. /// </exception> /// <exception cref="DirectoryNotFoundException"> /// One of The <see cref="StorageElement"/>'s parent folders does not exist. /// </exception> public static Task CreateOrUseExistingAsync( this StorageElement element, CancellationToken cancellationToken = default ) { _ = element ?? throw new ArgumentNullException(nameof(element)); return(element.CreateAsync(recursive: false, CreationCollisionOption.UseExisting, cancellationToken)); }
/// <summary> /// Recursively creates The <see cref="StorageElement"/> and all of its non-existing parent folders. /// An exception is thrown if The <see cref="StorageElement"/> already exists. /// </summary> /// <param name="element">The <see cref="StorageElement"/>.</param> /// <param name="cancellationToken"> /// A <see cref="CancellationToken"/> which can be used to cancel the asynchronous operation. /// </param> /// <remarks> /// Calling this method is equivalent to calling /// <see cref="StorageElement.CreateAsync(bool, CreationCollisionOption, CancellationToken)"/> /// with the <c>recursive: true</c> and <see cref="CreationCollisionOption.Fail"/> /// parameters. /// </remarks> /// <exception cref="ArgumentNullException"> /// <paramref name="element"/> is <see langword="null"/>. /// </exception> /// <exception cref="OperationCanceledException"> /// The operation was cancelled via the specified <paramref name="cancellationToken"/>. /// </exception> /// <exception cref="UnauthorizedAccessException"> /// Access to The <see cref="StorageElement"/> is restricted. /// </exception> /// <exception cref="PathTooLongException"> /// The length of The <see cref="StorageElement"/>'s path exceeds the system-defined maximum length. /// </exception> /// <exception cref="IOException"> /// The <see cref="StorageElement"/> already exists. /// /// -or- /// /// The <see cref="StorageElement"/> is a <see cref="StorageFile"/> (or <see cref="StorageFolder"/>) and a /// conflicting folder (or file) exists at its path. /// /// -or- /// /// An undefined I/O error occured while interacting with the file system. /// </exception> public static Task CreateRecursivelyAsync( this StorageElement element, CancellationToken cancellationToken = default ) { _ = element ?? throw new ArgumentNullException(nameof(element)); return(element.CreateAsync(recursive: true, CreationCollisionOption.Fail, cancellationToken)); }