Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/mcs
diff options
context:
space:
mode:
authorAlexander Köplinger <alex.koeplinger@outlook.com>2017-10-13 20:01:03 +0300
committerAlexander Köplinger <alex.koeplinger@outlook.com>2017-10-17 15:12:24 +0300
commite8ad2487f3b928bb7e54af7a0aeffbad4042b749 (patch)
tree5e077ca1bd697ce91b0e6eacbf4a24f99dd987a9 /mcs
parent4c4d3dcdc52541360cebe367901cff2598a81692 (diff)
[corlib] Use Latin1Encoding from referencesource
Fixes https://bugzilla.xamarin.com/show_bug.cgi?id=53296
Diffstat (limited to 'mcs')
-rw-r--r--mcs/class/corlib/Makefile2
-rw-r--r--mcs/class/corlib/System.Text/Latin1Encoding.cs353
-rw-r--r--mcs/class/corlib/Test/System.Text/Latin1EncodingTest.cs2
-rw-r--r--mcs/class/corlib/corlib.dll.sources3
4 files changed, 4 insertions, 356 deletions
diff --git a/mcs/class/corlib/Makefile b/mcs/class/corlib/Makefile
index f7b86001090..93ee919dfda 100644
--- a/mcs/class/corlib/Makefile
+++ b/mcs/class/corlib/Makefile
@@ -50,7 +50,7 @@ RESOURCE_FILES = \
resources/collation.cjkKOlv2.bin \
LinkerDescriptor/mscorlib.xml
-REFERENCE_SOURCES_FLAGS = -d:FEATURE_PAL,GENERICS_WORK,FEATURE_LIST_PREDICATES,FEATURE_SERIALIZATION,FEATURE_ASCII,FEATURE_LATIN1,FEATURE_UTF7,FEATURE_UTF32,MONO_HYBRID_ENCODING_SUPPORT,FEATURE_ASYNC_IO,NEW_EXPERIMENTAL_ASYNC_IO,FEATURE_UTF32,FEATURE_EXCEPTIONDISPATCHINFO,FEATURE_CORRUPTING_EXCEPTIONS,FEATURE_EXCEPTION_NOTIFICATIONS,FEATURE_STRONGNAME_MIGRATION,FEATURE_USE_LCID,FEATURE_FUSION,FEATURE_CRYPTO,FEATURE_X509_SECURESTRINGS,FEATURE_SYNCHRONIZATIONCONTEXT,FEATURE_SYNCHRONIZATIONCONTEXT_WAIT,HAS_CORLIB_CONTRACTS
+REFERENCE_SOURCES_FLAGS = -d:FEATURE_PAL,GENERICS_WORK,FEATURE_LIST_PREDICATES,FEATURE_SERIALIZATION,FEATURE_ENCODINGNLS,FEATURE_ASCII,FEATURE_LATIN1,FEATURE_UTF7,FEATURE_UTF32,MONO_HYBRID_ENCODING_SUPPORT,FEATURE_ASYNC_IO,NEW_EXPERIMENTAL_ASYNC_IO,FEATURE_UTF32,FEATURE_EXCEPTIONDISPATCHINFO,FEATURE_CORRUPTING_EXCEPTIONS,FEATURE_EXCEPTION_NOTIFICATIONS,FEATURE_STRONGNAME_MIGRATION,FEATURE_USE_LCID,FEATURE_FUSION,FEATURE_CRYPTO,FEATURE_X509_SECURESTRINGS,FEATURE_SYNCHRONIZATIONCONTEXT,FEATURE_SYNCHRONIZATIONCONTEXT_WAIT,HAS_CORLIB_CONTRACTS
ifndef MOBILE_PROFILE
REFERENCE_SOURCES_FLAGS += -d:FEATURE_MACL
diff --git a/mcs/class/corlib/System.Text/Latin1Encoding.cs b/mcs/class/corlib/System.Text/Latin1Encoding.cs
deleted file mode 100644
index 0d87d5624e9..00000000000
--- a/mcs/class/corlib/System.Text/Latin1Encoding.cs
+++ /dev/null
@@ -1,353 +0,0 @@
-/*
- * Latin1Encoding.cs - Implementation of the
- * "System.Text.Latin1Encoding" class.
- *
- * Copyright (c) 2002 Southern Storm Software, Pty Ltd
- *
- * Permission is hereby granted, free of charge, to any person obtaining
- * a copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included
- * in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
- * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
- * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- */
-
-namespace System.Text
-{
-
-using System;
-
-[Serializable]
-internal class Latin1Encoding : Encoding
-{
- // until we change the callers:
- internal static string _ (string arg) {
- return arg;
- }
-
- // Magic number used by Windows for the ISO Latin1 code page.
- internal const int ISOLATIN_CODE_PAGE = 28591;
-
- // Constructor.
- public Latin1Encoding () : base (ISOLATIN_CODE_PAGE)
- {
- // Nothing to do here.
- }
-
- public override bool IsSingleByte {
- get { return true; }
- }
-
- public override bool IsAlwaysNormalized (NormalizationForm form)
- {
- return form == NormalizationForm.FormC;
- }
-
- // Get the number of bytes needed to encode a character buffer.
- public override int GetByteCount (char[] chars, int index, int count)
- {
- if (chars == null) {
- throw new ArgumentNullException ("chars");
- }
- if (index < 0 || index > chars.Length) {
- throw new ArgumentOutOfRangeException ("index", _("ArgRange_Array"));
- }
- if (count < 0 || count > (chars.Length - index)) {
- throw new ArgumentOutOfRangeException ("count", _("ArgRange_Array"));
- }
- return count;
- }
-
- // Convenience wrappers for "GetByteCount".
- public override int GetByteCount (String s)
- {
- if (s == null) {
- throw new ArgumentNullException ("s");
- }
- return s.Length;
- }
-
- // Get the bytes that result from encoding a character buffer.
- public override int GetBytes (char[] chars, int charIndex, int charCount,
- byte[] bytes, int byteIndex)
- {
- EncoderFallbackBuffer buffer = null;
- char [] fallback_chars = null;
- return GetBytes (chars, charIndex, charCount, bytes,
- byteIndex, ref buffer, ref fallback_chars);
- }
-
- int GetBytes (char[] chars, int charIndex, int charCount,
- byte[] bytes, int byteIndex,
- ref EncoderFallbackBuffer buffer,
- ref char [] fallback_chars)
- {
- if (chars == null)
- throw new ArgumentNullException ("chars");
-
- unsafe {
- fixed (char *cptr = chars) {
- return InternalGetBytes (cptr, chars.Length, charIndex, charCount, bytes, byteIndex, ref buffer, ref fallback_chars);
- }
- }
- }
-
- // Convenience wrappers for "GetBytes".
- public override int GetBytes (String s, int charIndex, int charCount,
- byte[] bytes, int byteIndex)
- {
- EncoderFallbackBuffer buffer = null;
- char [] fallback_chars = null;
- return GetBytes (s, charIndex, charCount, bytes, byteIndex,
- ref buffer, ref fallback_chars);
- }
-
- int GetBytes (String s, int charIndex, int charCount,
- byte[] bytes, int byteIndex,
- ref EncoderFallbackBuffer buffer,
- ref char [] fallback_chars)
- {
- if (s == null)
- throw new ArgumentNullException ("s");
-
- unsafe {
- fixed (char *chars = s) {
- return InternalGetBytes (chars, s.Length, charIndex, charCount, bytes, byteIndex, ref buffer, ref fallback_chars);
- }
- }
- }
-
- unsafe int InternalGetBytes (char *chars, int charLength, int charIndex, int charCount,
- byte[] bytes, int byteIndex,
- ref EncoderFallbackBuffer buffer,
- ref char [] fallback_chars)
- {
- if (bytes == null)
- throw new ArgumentNullException ("bytes");
- if (charIndex < 0 || charIndex > charLength)
- throw new ArgumentOutOfRangeException ("charIndex", _("ArgRange_Array"));
- if (charCount < 0 || charCount > (charLength - charIndex))
- throw new ArgumentOutOfRangeException ("charCount", _("ArgRange_Array"));
- if (byteIndex < 0 || byteIndex > bytes.Length)
- throw new ArgumentOutOfRangeException ("byteIndex", _("ArgRange_Array"));
- if ((bytes.Length - byteIndex) < charCount)
- throw new ArgumentException (_("Arg_InsufficientSpace"));
-
- int count = charCount;
- char ch;
- while (count-- > 0) {
- ch = chars [charIndex++];
- if (ch < (char)0x0100) {
- bytes [byteIndex++] = (byte)ch;
- } else if (ch >= '\uFF01' && ch <= '\uFF5E') {
- bytes [byteIndex++] = (byte)(ch - 0xFEE0);
- } else {
- if (buffer == null)
- buffer = EncoderFallback.CreateFallbackBuffer ();
- if (Char.IsSurrogate (ch) && count > 1 &&
- Char.IsSurrogate (chars [charIndex]))
- {
- buffer.Fallback (ch, chars [charIndex], charIndex - 1);
- charIndex++;
- count--;
- }
- else
- buffer.Fallback (ch, charIndex - 1);
- if (fallback_chars == null || fallback_chars.Length < buffer.Remaining)
- fallback_chars = new char [buffer.Remaining];
- for (int i = 0; i < fallback_chars.Length; i++)
- fallback_chars [i] = buffer.GetNextChar ();
- byteIndex += GetBytes (fallback_chars, 0,
- fallback_chars.Length, bytes, byteIndex,
- ref buffer, ref fallback_chars);
- }
- }
- return charCount;
- }
-
- // Get the number of characters needed to decode a byte buffer.
- public override int GetCharCount (byte[] bytes, int index, int count)
- {
- if (bytes == null) {
- throw new ArgumentNullException ("bytes");
- }
- if (index < 0 || index > bytes.Length) {
- throw new ArgumentOutOfRangeException ("index", _("ArgRange_Array"));
- }
- if (count < 0 || count > (bytes.Length - index)) {
- throw new ArgumentOutOfRangeException ("count", _("ArgRange_Array"));
- }
- return count;
- }
-
- // Get the characters that result from decoding a byte buffer.
- public override int GetChars (byte[] bytes, int byteIndex, int byteCount,
- char[] chars, int charIndex)
- {
- if (bytes == null) {
- throw new ArgumentNullException ("bytes");
- }
- if (chars == null) {
- throw new ArgumentNullException ("chars");
- }
- if (byteIndex < 0 || byteIndex > bytes.Length) {
- throw new ArgumentOutOfRangeException ("byteIndex", _("ArgRange_Array"));
- }
- if (byteCount < 0 || byteCount > (bytes.Length - byteIndex)) {
- throw new ArgumentOutOfRangeException ("byteCount", _("ArgRange_Array"));
- }
- if (charIndex < 0 || charIndex > chars.Length) {
- throw new ArgumentOutOfRangeException ("charIndex", _("ArgRange_Array"));
- }
- if ((chars.Length - charIndex) < byteCount) {
- throw new ArgumentException (_("Arg_InsufficientSpace"));
- }
- int count = byteCount;
- while (count-- > 0) {
- chars [charIndex++] = (char)(bytes [byteIndex++]);
- }
- return byteCount;
- }
-
- // Get the maximum number of bytes needed to encode a
- // specified number of characters.
- public override int GetMaxByteCount (int charCount)
- {
- if (charCount < 0) {
- throw new ArgumentOutOfRangeException ("charCount", _("ArgRange_NonNegative"));
- }
- return charCount;
- }
-
- // Get the maximum number of characters needed to decode a
- // specified number of bytes.
- public override int GetMaxCharCount (int byteCount)
- {
- if (byteCount < 0) {
- throw new ArgumentOutOfRangeException ("byteCount", _("ArgRange_NonNegative"));
- }
- return byteCount;
- }
-
- // Decode a buffer of bytes into a string.
- public override String GetString (byte[] bytes, int index, int count)
- {
- if (bytes == null) {
- throw new ArgumentNullException ("bytes");
- }
- if (index < 0 || index > bytes.Length) {
- throw new ArgumentOutOfRangeException ("index", _("ArgRange_Array"));
- }
- if (count < 0 || count > (bytes.Length - index)) {
- throw new ArgumentOutOfRangeException ("count", _("ArgRange_Array"));
- }
- if (count == 0)
- return String.Empty;
- unsafe {
- fixed (byte* bytePtr = bytes) {
- string s = string.FastAllocateString (count);
-
- fixed (char* charPtr = s) {
- byte* currByte = bytePtr + index;
- byte* lastByte = currByte + count;
- char* currChar = charPtr;
-
- while (currByte < lastByte)
- currChar++ [0] = (char) currByte++ [0];
- }
-
- return s;
- }
- }
- }
- public override String GetString (byte[] bytes)
- {
- if (bytes == null) {
- throw new ArgumentNullException ("bytes");
- }
-
- return GetString (bytes, 0, bytes.Length);
- }
-
-#if !ECMA_COMPAT
-
- // Get the mail body name for this encoding.
- public override String BodyName
- {
- get {
- return "iso-8859-1";
- }
- }
-
- // Get the human-readable name for this encoding.
- public override String EncodingName
- {
- get {
- return "Western European (ISO)";
- }
- }
-
- // Get the mail agent header name for this encoding.
- public override String HeaderName
- {
- get {
- return "iso-8859-1";
- }
- }
-
- // Determine if this encoding can be displayed in a Web browser.
- public override bool IsBrowserDisplay
- {
- get {
- return true;
- }
- }
-
- // Determine if this encoding can be saved from a Web browser.
- public override bool IsBrowserSave
- {
- get {
- return true;
- }
- }
-
- // Determine if this encoding can be displayed in a mail/news agent.
- public override bool IsMailNewsDisplay
- {
- get {
- return true;
- }
- }
-
- // Determine if this encoding can be saved from a mail/news agent.
- public override bool IsMailNewsSave
- {
- get {
- return true;
- }
- }
-
- // Get the IANA-preferred Web name for this encoding.
- public override String WebName
- {
- get {
- return "iso-8859-1";
- }
- }
-
-#endif // !ECMA_COMPAT
-
-}; // class Latin1Encoding
-
-}; // namespace System.Text
diff --git a/mcs/class/corlib/Test/System.Text/Latin1EncodingTest.cs b/mcs/class/corlib/Test/System.Text/Latin1EncodingTest.cs
index c96da97d9c1..6775cb96158 100644
--- a/mcs/class/corlib/Test/System.Text/Latin1EncodingTest.cs
+++ b/mcs/class/corlib/Test/System.Text/Latin1EncodingTest.cs
@@ -105,7 +105,7 @@ namespace MonoTests.System.Text
byte[] bytes = latin1_encoding.GetBytes(testchars);
Assert.AreEqual ('T', (char) bytes [0], "#1");
Assert.AreEqual ('e', (char) bytes [1], "#2");
- Assert.AreEqual ('?', (char) bytes [2], "#3");
+ Assert.AreEqual ('A', (char) bytes [2], "#3");
Assert.AreEqual ('t', (char) bytes [3], "#4");
}
diff --git a/mcs/class/corlib/corlib.dll.sources b/mcs/class/corlib/corlib.dll.sources
index 9127f396014..c6d48c39413 100644
--- a/mcs/class/corlib/corlib.dll.sources
+++ b/mcs/class/corlib/corlib.dll.sources
@@ -826,7 +826,6 @@ System.Security.Principal/WindowsImpersonationContext.cs
System.Security.Principal/WindowsPrincipal.cs
System.Text/EncodingHelper.cs
System.Text/NormalizationForm.cs
-System.Text/Latin1Encoding.cs
System.Threading/CompressedStack.cs
System.Threading/HostExecutionContext.cs
System.Threading/HostExecutionContextManager.cs
@@ -1484,7 +1483,9 @@ ReferenceSources/AppContextDefaultValues.cs
../referencesource/mscorlib/system/text/encoderreplacementfallback.cs
../referencesource/mscorlib/system/text/encoding.cs
../referencesource/mscorlib/system/text/encodinginfo.cs
+../referencesource/mscorlib/system/text/encodingnls.cs
../referencesource/mscorlib/system/text/encodingprovider.cs
+../referencesource/mscorlib/system/text/latin1encoding.cs
../referencesource/mscorlib/system/text/mlangcodepageencoding.cs
../referencesource/mscorlib/system/text/surrogateencoder.cs
../referencesource/mscorlib/system/text/unicodeencoding.cs