-
Notifications
You must be signed in to change notification settings - Fork 4.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add Convert Span-based APIs #22848
Comments
We agreed in the API review to revert back to the original proposal: namespace System
{
public class Convert
{
public static string ToBase64String(ReadOnlySpan<byte> bytes, Base64FormattingOptions options = Base64FormattingOptions.None);
public static bool TryToBase64Chars(ReadOnlySpan<byte> bytes, Span<char> chars, out int charsWritten, Base64FormattingOptions options = Base64FormattingOptions.None);
public static bool TryFromBase64String(string s, Span<byte> bytes, out int bytesWritten);
public static bool TryFromBase64Chars(ReadOnlySpan<char> chars, Span<byte> bytes, out int bytesWritten);
…
}
} |
@stephentoub I thought we decided to postpone the decision for later, rather than making a decision ... https://github.com/dotnet/apireviews/blob/master/2017/10-03-GitHub%20issues.md |
We decided to postpone discussion of TransformationStatus. I just re-watched starting from 1:13:30... it seems like we agreed to go back to the original thing proposed without TransformationStatus, no? |
@stephentoub it's quite possible, I didn't pay too much attention. If you think it is non-controversial, I am fine. |
@bartonjs, @KrzysztofCwalina, can you confirm my recollection? |
We postponed adding TransformationStatus to the core. The reason being that Convert APIs should stay simple for scenarios where a single buffer is being manipulated. TransformationStatus adds very significant complexity and is only useful when dis contiguous buffers need to be processed. |
IIRC I was the original proponent of using TransformationStatus for Base64. In the Tuesday meeting I said I'd changed my mind and thought simple bool-Try was sufficient; but then I had to leave. Assuming no one else disagreed after I left, seems good to me. |
Has there been a discussion about adding internal abstract object FromString(string value, int radix);
// ...
return FromString(text.Substring(2), 16); We could get some perf benefits in situations where the radix is needed? |
@hughbe I was thinking too about these methods of System.Convert in particular: static class Convert {
public static char ToBoolean(string value);
public static char ToChar(string value);
public static short ToInt16(string value);
public static int ToInt32(string value);
public static long ToInt64(string value);
public static decimal ToDecimal(string value);
public static double ToDouble(string value);
// ...
} Anything that prevents us from creating overloads that accept As fas as i can tall, the |
Separated out of https://github.com/dotnet/corefx/issues/21281 for tracking purposes.
Mostly approved, but needed to re-verify approach with TransformationStatus.
Depends on https://github.com/dotnet/corefx/issues/22412.
The text was updated successfully, but these errors were encountered: