IDebugDocumentText2::GetText
Pobiera tekst z określonej pozycji w dokumencie.
Składnia
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;
}
}
}