Udostępnij za pośrednictwem


IDebugDocumentText2::GetText

Pobiera tekst z określonej pozycji w dokumencie.

Składnia

int GetText(
    eumn_TEXT_POSITION pos,
    uint               cMaxChars,
    IntPtr             pText,
    out uint           pcNumChars
);

Parametry

pos
[in] Struktura TEXT_POSITION wskazująca lokalizację tekstu do pobrania.

cMaxChars
[in] Maksymalna liczba znaków tekstu do pobrania.

pText
[in, out] Wskaźnik do buforu, który ma zostać wypełniony żądanym tekstem. Ten bufor musi być w stanie zawierać co najmniej cMaxChars liczbę znaków szerokich.

pcNumChars
[out] Zwraca liczbę faktycznie pobranych znaków.

Wartość zwracana

Jeśli operacja powiedzie się, zwraca wartość S_OK; w przeciwnym razie zwraca kod błędu.

Przykład

W tym przykładzie pokazano, jak można wywołać tę metodę z języka C#.

using System.Runtime.Interop.Services;
using Microsoft.VisualStudio;
using Microsoft.VisualStudio.Debugger.Interop;

namespace Mynamespace
{
    class MyClass
    {
        string GetDocumentText(IDebugDocumentText2 pText, TEXT_POSITION pos)
        {
            string documentText = string.Empty;
            if (pText != null)
            {
                uint numLines = 0;
                uint numChars = 0;
                int hr;
                hr = pText.GetSize(ref numLines, ref numChars);
                if (ErrorHandler.Succeeded(hr))
                {
                    IntPtr buffer = Marshal.AllocCoTaskMem((int)numChars * sizeof(char));
                    uint actualChars = 0;
                    hr = pText.GetText(pos, numChars, buffer, out actualChars);
                    if (ErrorHandler.Succeeded(hr))
                    {
                        documentText = Marshal.PtrToStringUni(buffer, (int)actualChars);
                    }
                    Marshal.FreeCoTaskMem(buffer);
                }
            }
            return documentText;
        }
    }
}

Zobacz też