aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/Utilities/StringUtils.cs
diff options
context:
space:
mode:
authorMary <me@thog.eu>2021-10-25 00:13:20 +0200
committerGitHub <noreply@github.com>2021-10-24 19:13:20 -0300
commit51fa1b2cb0bb54c0eb235c9d1fa68a7e1abaf464 (patch)
tree8f47d8391bc4c2b994ccf872ca123fdd1dbb9288 /Ryujinx.HLE/Utilities/StringUtils.cs
parentb4dc33efc2890bc0d60e99f715425d6af4a72b3d (diff)
hle: Improve safety (#2778)
* timezone: Make timezone implementation safe * hle: Do not use TrimEnd to parse ASCII strings This adds an util that handle reading an ASCII string in a safe way. Previously it was possible to read malformed data that could cause various undefined behaviours in multiple services. * hid: Remove an useless unsafe modifier on keyboard update * Address gdkchan's comment * Address gdkchan's comment
Diffstat (limited to 'Ryujinx.HLE/Utilities/StringUtils.cs')
-rw-r--r--Ryujinx.HLE/Utilities/StringUtils.cs13
1 files changed, 11 insertions, 2 deletions
diff --git a/Ryujinx.HLE/Utilities/StringUtils.cs b/Ryujinx.HLE/Utilities/StringUtils.cs
index 4142ab5b..2b7cbffe 100644
--- a/Ryujinx.HLE/Utilities/StringUtils.cs
+++ b/Ryujinx.HLE/Utilities/StringUtils.cs
@@ -36,6 +36,15 @@ namespace Ryujinx.HLE.Utilities
return output;
}
+ public static string ReadInlinedAsciiString(BinaryReader reader, int maxSize)
+ {
+ byte[] data = reader.ReadBytes(maxSize);
+
+ int stringSize = Array.IndexOf<byte>(data, 0);
+
+ return Encoding.ASCII.GetString(data, 0, stringSize < 0 ? maxSize : stringSize);
+ }
+
public static byte[] HexToBytes(string hexString)
{
// Ignore last character if HexLength % 2 != 0.
@@ -107,7 +116,7 @@ namespace Ryujinx.HLE.Utilities
}
}
- public static unsafe int CompareCStr(char* s1, char* s2)
+ public static int CompareCStr(ReadOnlySpan<char> s1, ReadOnlySpan<char> s2)
{
int s1Index = 0;
int s2Index = 0;
@@ -121,7 +130,7 @@ namespace Ryujinx.HLE.Utilities
return s2[s2Index] - s1[s1Index];
}
- public static unsafe int LengthCstr(char* s)
+ public static int LengthCstr(ReadOnlySpan<char> s)
{
int i = 0;