/// <summary>Flushes this encoder.</summary>
 /// <remarks>
 /// Flushes this encoder.
 /// <p>
 /// This method will call
 /// <see cref="implFlush(java.nio.ByteBuffer)">implFlush</see>
 /// . Some
 /// encoders may need to write some bytes to the output buffer when they have
 /// read all input characters, subclasses can overridden
 /// <see cref="implFlush(java.nio.ByteBuffer)">implFlush</see>
 /// to perform writing action.
 /// <p>
 /// The maximum number of written bytes won't larger than
 /// <see cref="java.nio.Buffer.remaining()">out.remaining()</see>
 /// . If some encoder wants to
 /// write more bytes than the output buffer's available remaining space, then
 /// <code>CoderResult.OVERFLOW</code> will be returned, and this method
 /// must be called again with a byte buffer that has free space. Otherwise
 /// this method will return <code>CoderResult.UNDERFLOW</code>, which
 /// means one encoding process has been completed successfully.
 /// <p>
 /// During the flush, the output buffer's position will be changed
 /// accordingly, while its mark and limit will be intact.
 /// </remarks>
 /// <param name="out">the given output buffer.</param>
 /// <returns>
 /// <code>CoderResult.UNDERFLOW</code> or
 /// <code>CoderResult.OVERFLOW</code>.
 /// </returns>
 /// <exception cref="System.InvalidOperationException">
 /// if this encoder hasn't read all input characters during one
 /// encoding process, which means neither after calling
 /// <see cref="encode(java.nio.CharBuffer)">encode(CharBuffer)</see>
 /// nor after
 /// calling
 /// <see cref="encode(java.nio.CharBuffer, java.nio.ByteBuffer, bool)">encode(CharBuffer, ByteBuffer, boolean)
 ///     </see>
 /// with
 /// <code>true</code>
 /// for the last boolean parameter.
 /// </exception>
 public java.nio.charset.CoderResult flush(java.nio.ByteBuffer @out)
 {
     if (status != END && status != READY)
     {
         throw new System.InvalidOperationException();
     }
     java.nio.charset.CoderResult result = implFlush(@out);
     if (result == java.nio.charset.CoderResult.UNDERFLOW)
     {
         status = FLUSH;
     }
     return(result);
 }
 // default implementation is empty
 /// <summary>
 /// Checks if the given argument is legal as this encoder's replacement byte
 /// array.
 /// </summary>
 /// <remarks>
 /// Checks if the given argument is legal as this encoder's replacement byte
 /// array.
 /// The given byte array is legal if and only if it can be decode into
 /// sixteen bits Unicode characters.
 /// This method can be overridden for performance improvement.
 /// </remarks>
 /// <param name="replacement">the given byte array to be checked.</param>
 /// <returns>
 /// true if the the given argument is legal as this encoder's
 /// replacement byte array.
 /// </returns>
 public virtual bool isLegalReplacement(byte[] replacement_1)
 {
     if (decoder == null)
     {
         decoder = cs.newDecoder();
         decoder.onMalformedInput(java.nio.charset.CodingErrorAction.REPORT);
         decoder.onUnmappableCharacter(java.nio.charset.CodingErrorAction.REPORT);
     }
     java.nio.ByteBuffer @in  = java.nio.ByteBuffer.wrap(replacement_1);
     java.nio.CharBuffer @out = java.nio.CharBuffer.allocate((int)(replacement_1.Length
                                                                   * decoder.maxCharsPerByte()));
     java.nio.charset.CoderResult result = decoder.decode(@in, @out, true);
     return(!result.isError());
 }
 /// <exception cref="java.nio.charset.CharacterCodingException"></exception>
 private void checkCoderResult(java.nio.charset.CoderResult result)
 {
     if (_malformedInputAction == java.nio.charset.CodingErrorAction.REPORT && result.
         isMalformed())
     {
         throw new java.nio.charset.MalformedInputException(result.length());
     }
     else
     {
         if (_unmappableCharacterAction == java.nio.charset.CodingErrorAction.REPORT && result
             .isUnmappable())
         {
             throw new java.nio.charset.UnmappableCharacterException(result.length());
         }
     }
 }
        /// <summary>This is a facade method for the decoding operation.</summary>
        /// <remarks>
        /// This is a facade method for the decoding operation.
        /// <p>
        /// This method decodes the remaining byte sequence of the given byte buffer
        /// into a new character buffer. This method performs a complete decoding
        /// operation, resets at first, then decodes, and flushes at last.
        /// <p>
        /// This method should not be invoked while another
        /// <code>decode</code>
        /// operation
        /// is ongoing.
        /// </remarks>
        /// <param name="in">the input buffer.</param>
        /// <returns>
        /// a new <code>CharBuffer</code> containing the the characters
        /// produced by this decoding operation. The buffer's limit will be
        /// the position of the last character in the buffer, and the
        /// position will be zero.
        /// </returns>
        /// <exception cref="System.InvalidOperationException">if another decoding operation is ongoing.
        ///     </exception>
        /// <exception cref="MalformedInputException">
        /// if an illegal input byte sequence for this charset was
        /// encountered, and the action for malformed error is
        /// <see cref="CodingErrorAction.REPORT">CodingErrorAction.REPORT</see>
        /// </exception>
        /// <exception cref="UnmappableCharacterException">
        /// if a legal but unmappable input byte sequence for this
        /// charset was encountered, and the action for unmappable
        /// character error is
        /// <see cref="CodingErrorAction.REPORT">CodingErrorAction.REPORT</see>
        /// .
        /// Unmappable means the byte sequence at the input buffer's
        /// current position cannot be mapped to a Unicode character
        /// sequence.
        /// </exception>
        /// <exception cref="CharacterCodingException">if another exception happened during the decode operation.
        ///     </exception>
        /// <exception cref="java.nio.charset.CharacterCodingException"></exception>
        public java.nio.CharBuffer decode(java.nio.ByteBuffer @in)
        {
            reset();
            int length = (int)(@in.remaining() * _averageCharsPerByte);

            java.nio.CharBuffer          output = java.nio.CharBuffer.allocate(length);
            java.nio.charset.CoderResult result = null;
            while (true)
            {
                result = decode(@in, output, false);
                checkCoderResult(result);
                if (result.isUnderflow())
                {
                    break;
                }
                else
                {
                    if (result.isOverflow())
                    {
                        output = allocateMore(output);
                    }
                }
            }
            result = decode(@in, output, true);
            checkCoderResult(result);
            while (true)
            {
                result = flush(output);
                checkCoderResult(result);
                if (result.isOverflow())
                {
                    output = allocateMore(output);
                }
                else
                {
                    break;
                }
            }
            output.flip();
            status = FLUSH;
            return(output);
        }
Exemple #5
0
 /// <exception cref="System.IO.IOException"></exception>
 private void drainEncoder()
 {
     // Strictly speaking, I think it's part of the CharsetEncoder contract that you call
     // encode with endOfInput true before flushing. Our ICU-based implementations don't
     // actually need this, and you'd hope that any reasonable implementation wouldn't either.
     // CharsetEncoder.encode doesn't actually pass the boolean through to encodeLoop anyway!
     java.nio.CharBuffer chars = java.nio.CharBuffer.allocate(0);
     while (true)
     {
         java.nio.charset.CoderResult result = encoder.encode(chars, bytes, true);
         if (result.isError())
         {
             result.throwException();
         }
         else
         {
             if (result.isOverflow())
             {
                 flushBytes(false);
                 continue;
             }
         }
         break;
     }
     // Some encoders (such as ISO-2022-JP) have stuff to write out after all the
     // characters (such as shifting back into a default state). In our implementation,
     // this is actually the first time ICU is told that we've run out of input.
     java.nio.charset.CoderResult result_1 = encoder.flush(bytes);
     while (!result_1.isUnderflow())
     {
         if (result_1.isOverflow())
         {
             flushBytes(false);
             result_1 = encoder.flush(bytes);
         }
         else
         {
             result_1.throwException();
         }
     }
 }
Exemple #6
0
 /// <exception cref="System.IO.IOException"></exception>
 private void convert(java.nio.CharBuffer chars)
 {
     while (true)
     {
         java.nio.charset.CoderResult result = encoder.encode(chars, bytes, false);
         if (result.isOverflow())
         {
             // Make room and try again.
             flushBytes(false);
             continue;
         }
         else
         {
             if (result.isError())
             {
                 result.throwException();
             }
         }
         break;
     }
 }
Exemple #7
0
 /// <summary>
 /// Gets a <code>CoderResult</code> object indicating a malformed-input
 /// error.
 /// </summary>
 /// <remarks>
 /// Gets a <code>CoderResult</code> object indicating a malformed-input
 /// error.
 /// </remarks>
 /// <param name="length">the length of the malformed-input.</param>
 /// <returns>
 /// a <code>CoderResult</code> object indicating a malformed-input
 /// error.
 /// </returns>
 /// <exception cref="System.ArgumentException">if <code>length</code> is non-positive.
 ///     </exception>
 public static java.nio.charset.CoderResult malformedForLength(int length_1)
 {
     lock (typeof(CoderResult))
     {
         if (length_1 > 0)
         {
             int key = Sharpen.Util.IntValueOf(length_1);
             lock (_malformedErrors)
             {
                 java.nio.charset.CoderResult r = _malformedErrors.get(key);
                 if (r == null)
                 {
                     r = new java.nio.charset.CoderResult(TYPE_MALFORMED_INPUT, length_1);
                     _malformedErrors.put(key, r);
                 }
                 return(r);
             }
         }
         throw new System.ArgumentException("Length must be greater than 0; was " + length_1
                                            );
     }
 }
Exemple #8
0
 /// <summary>
 /// Gets a <code>CoderResult</code> object indicating an unmappable
 /// character error.
 /// </summary>
 /// <remarks>
 /// Gets a <code>CoderResult</code> object indicating an unmappable
 /// character error.
 /// </remarks>
 /// <param name="length">
 /// the length of the input unit sequence denoting the unmappable
 /// character.
 /// </param>
 /// <returns>
 /// a <code>CoderResult</code> object indicating an unmappable
 /// character error.
 /// </returns>
 /// <exception cref="System.ArgumentException">if <code>length</code> is non-positive.
 ///     </exception>
 public static java.nio.charset.CoderResult unmappableForLength(int length_1)
 {
     lock (typeof(CoderResult))
     {
         if (length_1 > 0)
         {
             int key = Sharpen.Util.IntValueOf(length_1);
             lock (_unmappableErrors)
             {
                 java.nio.charset.CoderResult r = _unmappableErrors.get(key);
                 if (r == null)
                 {
                     r = new java.nio.charset.CoderResult(TYPE_UNMAPPABLE_CHAR, length_1);
                     _unmappableErrors.put(key, r);
                 }
                 return(r);
             }
         }
         throw new System.ArgumentException("Length must be greater than 0; was " + length_1
                                            );
     }
 }
Exemple #9
0
 public virtual void flush()
 {
     //Log.i("PackageManager", "flush mPos=" + mPos);
     if (mPos > 0)
     {
         if (mOutputStream != null)
         {
             java.nio.CharBuffer          charBuffer = java.nio.CharBuffer.wrap(mText, 0, mPos);
             java.nio.charset.CoderResult result     = mCharset.encode(charBuffer, mBytes, true);
             while (true)
             {
                 if (result.isError())
                 {
                     throw new System.IO.IOException(result.ToString());
                 }
                 else
                 {
                     if (result.isOverflow())
                     {
                         flushBytes();
                         result = mCharset.encode(charBuffer, mBytes, true);
                         continue;
                     }
                 }
                 break;
             }
             flushBytes();
             mOutputStream.flush();
         }
         else
         {
             mWriter.write(mText, 0, mPos);
             mWriter.flush();
         }
         mPos = 0;
     }
 }
Exemple #10
0
        /// <summary>This is a facade method for the encoding operation.</summary>
        /// <remarks>
        /// This is a facade method for the encoding operation.
        /// <p>
        /// This method encodes the remaining character sequence of the given
        /// character buffer into a new byte buffer. This method performs a complete
        /// encoding operation, resets at first, then encodes, and flushes at last.
        /// <p>
        /// This method should not be invoked if another encode operation is ongoing.
        /// </remarks>
        /// <param name="in">the input buffer.</param>
        /// <returns>
        /// a new <code>ByteBuffer</code> containing the bytes produced by
        /// this encoding operation. The buffer's limit will be the position
        /// of the last byte in the buffer, and the position will be zero.
        /// </returns>
        /// <exception cref="System.InvalidOperationException">if another encoding operation is ongoing.
        ///     </exception>
        /// <exception cref="MalformedInputException">
        /// if an illegal input character sequence for this charset is
        /// encountered, and the action for malformed error is
        /// <see cref="CodingErrorAction.REPORT">CodingErrorAction.REPORT</see>
        /// </exception>
        /// <exception cref="UnmappableCharacterException">
        /// if a legal but unmappable input character sequence for this
        /// charset is encountered, and the action for unmappable
        /// character error is
        /// <see cref="CodingErrorAction.REPORT">CodingErrorAction.REPORT</see>
        /// .
        /// Unmappable means the Unicode character sequence at the input
        /// buffer's current position cannot be mapped to a equivalent
        /// byte sequence.
        /// </exception>
        /// <exception cref="CharacterCodingException">if other exception happened during the encode operation.
        ///     </exception>
        /// <exception cref="java.nio.charset.CharacterCodingException"></exception>
        public java.nio.ByteBuffer encode(java.nio.CharBuffer @in)
        {
            if (@in.remaining() == 0)
            {
                return(java.nio.ByteBuffer.allocate(0));
            }
            reset();
            int length = (int)(@in.remaining() * _averageBytesPerChar);

            java.nio.ByteBuffer          output = java.nio.ByteBuffer.allocate(length);
            java.nio.charset.CoderResult result = null;
            while (true)
            {
                result = encode(@in, output, false);
                if (result == java.nio.charset.CoderResult.UNDERFLOW)
                {
                    break;
                }
                else
                {
                    if (result == java.nio.charset.CoderResult.OVERFLOW)
                    {
                        output = allocateMore(output);
                        continue;
                    }
                }
                checkCoderResult(result);
            }
            result = encode(@in, output, true);
            checkCoderResult(result);
            while (true)
            {
                result = flush(output);
                if (result == java.nio.charset.CoderResult.UNDERFLOW)
                {
                    output.flip();
                    break;
                }
                else
                {
                    if (result == java.nio.charset.CoderResult.OVERFLOW)
                    {
                        output = allocateMore(output);
                        continue;
                    }
                }
                checkCoderResult(result);
                output.flip();
                if (result.isMalformed())
                {
                    throw new java.nio.charset.MalformedInputException(result.length());
                }
                else
                {
                    if (result.isUnmappable())
                    {
                        throw new java.nio.charset.UnmappableCharacterException(result.length());
                    }
                }
                break;
            }
            status   = READY;
            finished = true;
            return(output);
        }
Exemple #11
0
 public override int read(char[] buffer, int offset, int length)
 {
     lock (@lock)
     {
         if (!isOpen())
         {
             throw new System.IO.IOException("InputStreamReader is closed");
         }
         java.util.Arrays.checkOffsetAndCount(buffer.Length, offset, length);
         if (length == 0)
         {
             return(0);
         }
         java.nio.CharBuffer          @out   = java.nio.CharBuffer.wrap(buffer, offset, length);
         java.nio.charset.CoderResult result = java.nio.charset.CoderResult.UNDERFLOW;
         // bytes.remaining() indicates number of bytes in buffer
         // when 1-st time entered, it'll be equal to zero
         bool needInput = !bytes.hasRemaining();
         while (@out.hasRemaining())
         {
             // fill the buffer if needed
             if (needInput)
             {
                 try
                 {
                     if (@in.available() == 0 && @out.position() > offset)
                     {
                         // we could return the result without blocking read
                         break;
                     }
                 }
                 catch (System.IO.IOException)
                 {
                 }
                 // available didn't work so just try the read
                 int desiredByteCount = bytes.capacity() - bytes.limit();
                 int off             = bytes.arrayOffset() + bytes.limit();
                 int actualByteCount = @in.read(((byte[])bytes.array()), off, desiredByteCount);
                 if (actualByteCount == -1)
                 {
                     endOfInput = true;
                     break;
                 }
                 else
                 {
                     if (actualByteCount == 0)
                     {
                         break;
                     }
                 }
                 bytes.limit(bytes.limit() + actualByteCount);
                 needInput = false;
             }
             // decode bytes
             result = decoder.decode(bytes, @out, false);
             if (result.isUnderflow())
             {
                 // compact the buffer if no space left
                 if (bytes.limit() == bytes.capacity())
                 {
                     bytes.compact();
                     bytes.limit(bytes.position());
                     bytes.position(0);
                 }
                 needInput = true;
             }
             else
             {
                 break;
             }
         }
         if (result == java.nio.charset.CoderResult.UNDERFLOW && endOfInput)
         {
             result = decoder.decode(bytes, @out, true);
             decoder.flush(@out);
             decoder.reset();
         }
         if (result.isMalformed() || result.isUnmappable())
         {
             result.throwException();
         }
         return(@out.position() - offset == 0 ? -1 : @out.position() - offset);
     }
 }
Exemple #12
0
		/// <summary>
		/// Gets a <code>CoderResult</code> object indicating a malformed-input
		/// error.
		/// </summary>
		/// <remarks>
		/// Gets a <code>CoderResult</code> object indicating a malformed-input
		/// error.
		/// </remarks>
		/// <param name="length">the length of the malformed-input.</param>
		/// <returns>
		/// a <code>CoderResult</code> object indicating a malformed-input
		/// error.
		/// </returns>
		/// <exception cref="System.ArgumentException">if <code>length</code> is non-positive.
		/// 	</exception>
		public static java.nio.charset.CoderResult malformedForLength(int length_1)
		{
			lock (typeof(CoderResult))
			{
				if (length_1 > 0)
				{
					int key = Sharpen.Util.IntValueOf(length_1);
					lock (_malformedErrors)
					{
						java.nio.charset.CoderResult r = _malformedErrors.get(key);
						if (r == null)
						{
							r = new java.nio.charset.CoderResult(TYPE_MALFORMED_INPUT, length_1);
							_malformedErrors.put(key, r);
						}
						return r;
					}
				}
				throw new System.ArgumentException("Length must be greater than 0; was " + length_1
					);
			}
		}
Exemple #13
0
		/// <summary>
		/// Gets a <code>CoderResult</code> object indicating an unmappable
		/// character error.
		/// </summary>
		/// <remarks>
		/// Gets a <code>CoderResult</code> object indicating an unmappable
		/// character error.
		/// </remarks>
		/// <param name="length">
		/// the length of the input unit sequence denoting the unmappable
		/// character.
		/// </param>
		/// <returns>
		/// a <code>CoderResult</code> object indicating an unmappable
		/// character error.
		/// </returns>
		/// <exception cref="System.ArgumentException">if <code>length</code> is non-positive.
		/// 	</exception>
		public static java.nio.charset.CoderResult unmappableForLength(int length_1)
		{
			lock (typeof(CoderResult))
			{
				if (length_1 > 0)
				{
					int key = Sharpen.Util.IntValueOf(length_1);
					lock (_unmappableErrors)
					{
						java.nio.charset.CoderResult r = _unmappableErrors.get(key);
						if (r == null)
						{
							r = new java.nio.charset.CoderResult(TYPE_UNMAPPABLE_CHAR, length_1);
							_unmappableErrors.put(key, r);
						}
						return r;
					}
				}
				throw new System.ArgumentException("Length must be greater than 0; was " + length_1
					);
			}
		}
Exemple #14
0
 /// <summary>
 /// Decodes bytes starting at the current position of the given input buffer,
 /// and writes the equivalent character sequence into the given output buffer
 /// from its current position.
 /// </summary>
 /// <remarks>
 /// Decodes bytes starting at the current position of the given input buffer,
 /// and writes the equivalent character sequence into the given output buffer
 /// from its current position.
 /// <p>
 /// The buffers' position will be changed with the reading and writing
 /// operation, but their limits and marks will be kept intact.
 /// <p>
 /// A <code>CoderResult</code> instance will be returned according to
 /// following rules:
 /// <ul>
 /// <li>
 /// <see cref="CoderResult.OVERFLOW">CoderResult.OVERFLOW</see>
 /// indicates that
 /// even though not all of the input has been processed, the buffer the
 /// output is being written to has reached its capacity. In the event of this
 /// code being returned this method should be called once more with an
 /// <code>out</code> argument that has not already been filled.</li>
 /// <li>
 /// <see cref="CoderResult.UNDERFLOW">CoderResult.UNDERFLOW</see>
 /// indicates that
 /// as many bytes as possible in the input buffer have been decoded. If there
 /// is no further input and no remaining bytes in the input buffer then this
 /// operation may be regarded as complete. Otherwise, this method should be
 /// called once more with additional input.</li>
 /// <li>A
 /// <see cref="CoderResult.malformedForLength(int)">malformed input</see>
 /// result
 /// indicates that some malformed input error has been encountered, and the
 /// erroneous bytes start at the input buffer's position and their number can
 /// be got by result's
 /// <see cref="CoderResult.length()">length</see>
 /// . This kind of
 /// result can be returned only if the malformed action is
 /// <see cref="CodingErrorAction.REPORT">CodingErrorAction.REPORT</see>
 /// . </li>
 /// <li>A
 /// <see cref="CoderResult.unmappableForLength(int)">unmappable character</see>
 /// result indicates that some unmappable character error has been
 /// encountered, and the erroneous bytes start at the input buffer's position
 /// and their number can be got by result's
 /// <see cref="CoderResult.length()">length</see>
 /// . This kind of result can be returned
 /// only if the unmappable character action is
 /// <see cref="CodingErrorAction.REPORT">CodingErrorAction.REPORT</see>
 /// . </li>
 /// </ul>
 /// <p>
 /// The <code>endOfInput</code> parameter indicates that the invoker cannot
 /// provide further input. This parameter is true if and only if the bytes in
 /// current input buffer are all inputs for this decoding operation. Note
 /// that it is common and won't cause an error if the invoker sets false and
 /// then can't provide more input, while it may cause an error if the invoker
 /// always sets true in several consecutive invocations. This would make the
 /// remaining input to be treated as malformed input.
 /// <p>
 /// This method invokes the
 /// <see cref="decodeLoop(java.nio.ByteBuffer, java.nio.CharBuffer)">decodeLoop</see>
 /// method to
 /// implement the basic decode logic for a specific charset.
 /// </remarks>
 /// <param name="in">the input buffer.</param>
 /// <param name="out">the output buffer.</param>
 /// <param name="endOfInput">true if all the input characters have been provided.</param>
 /// <returns>
 /// a <code>CoderResult</code> instance which indicates the reason
 /// of termination.
 /// </returns>
 /// <exception cref="System.InvalidOperationException">
 /// if decoding has started or no more input is needed in this
 /// decoding progress.
 /// </exception>
 /// <exception cref="CoderMalfunctionError">
 /// if the
 /// <see cref="decodeLoop(java.nio.ByteBuffer, java.nio.CharBuffer)">decodeLoop</see>
 /// method threw an <code>BufferUnderflowException</code> or
 /// <code>BufferOverflowException</code>.
 /// </exception>
 public java.nio.charset.CoderResult decode(java.nio.ByteBuffer @in, java.nio.CharBuffer
                                            @out, bool endOfInput)
 {
     if ((status == FLUSH) || (!endOfInput && status == END))
     {
         throw new System.InvalidOperationException();
     }
     java.nio.charset.CoderResult result = null;
     // begin to decode
     while (true)
     {
         java.nio.charset.CodingErrorAction action = null;
         try
         {
             result = decodeLoop(@in, @out);
         }
         catch (java.nio.BufferOverflowException ex)
         {
             // unexpected exception
             throw new java.nio.charset.CoderMalfunctionError(ex);
         }
         catch (java.nio.BufferUnderflowException ex)
         {
             // unexpected exception
             throw new java.nio.charset.CoderMalfunctionError(ex);
         }
         if (result.isUnderflow())
         {
             int remaining = @in.remaining();
             status = endOfInput ? END : ONGOING;
             if (endOfInput && remaining > 0)
             {
                 result = java.nio.charset.CoderResult.malformedForLength(remaining);
             }
             else
             {
                 return(result);
             }
         }
         if (result.isOverflow())
         {
             return(result);
         }
         // set coding error handle action
         action = _malformedInputAction;
         if (result.isUnmappable())
         {
             action = _unmappableCharacterAction;
         }
         // If the action is IGNORE or REPLACE, we should continue decoding.
         if (action == java.nio.charset.CodingErrorAction.REPLACE)
         {
             if (@out.remaining() < replacementChars.Length)
             {
                 return(java.nio.charset.CoderResult.OVERFLOW);
             }
             @out.put(replacementChars);
         }
         else
         {
             if (action != java.nio.charset.CodingErrorAction.IGNORE)
             {
                 return(result);
             }
         }
         @in.position(@in.position() + result.length());
     }
 }