EditPoint Usage Example
The following example creates a TextDocument object, adds some text to it, and then demonstrates some EditPoint object functionality.
Example
Description
These functions are one-based for character offsets, whereas the IVsTextView and similar interfaces are zero-based. EditPoint is one-based because it is designed to support VB automation.
Code
Public Sub OnConnection(ByVal application As Object, ByVal connectMode_
As Extensibility.ext_ConnectMode, ByVal addInInst As Object,_
ByRef custom As System.Array) Implements_
Extensibility.IDTExtensibility2.OnConnection
applicationObject = CType(application, EnvDTE.DTE)
addInInstance = CType(addInInst, EnvDTE.AddIn)
EditPointExample1(applicationObject)
End Sub
Sub EditPointExample1(ByVal dte As DTE)
Dim objTextDoc As TextDocument
Dim objEditPt As EditPoint, iCtr As Integer
' Create a new text file.
applicationObject.ItemOperations.NewFile("General\Text File")
' Get a handle to the new document and create an EditPoint.
objTextDoc = applicationObject.ActiveDocument.Object("TextDocument")
objEditPt = objTextDoc.StartPoint.CreateEditPoint
' Insert ten lines of text.
For iCtr = 1 To 10
objEditPt.Insert("This is a test." & Chr(13))
Next iCtr
' Replace the eighth word on the third line with a new word.
objEditPt.StartOfDocument()
objEditPt.LineDown(3)
objEditPt.WordRight(3)
objEditPt.Delete(4)
objEditPt.Insert("raid")
' Indent a line.
objEditPt.LineDown(2)
objEditPt.StartOfLine()
objEditPt.Indent()
' Set some bookmarks.
objEditPt.LineDown(1)
' Set the first bookmark.
objEditPt.SetBookmark()
' Set the second bookmark on the next line.
objEditPt.LineDown(1)
objEditPt.SetBookmark()
' Go back to the first bookmark.
objEditPt.PreviousBookmark()
' Add some text there.
objEditPt.Insert("BOOKMARK 1: ")
' Do the same thing at the next bookmark.
objEditPt.NextBookmark()
objEditPt.Insert("BOOKMARK 2: ")
' Print the current line and character offset in the buffer.
MsgBox("Line and offset: " & objEditPt.Line, _
objEditPt.LineCharOffset())
' Capitalize the third word of the second line.
objEditPt.StartOfDocument()
objEditPt.LineDown(2)
objEditPt.WordRight(3)
objEditPt.ChangeCase(4, vsCaseOptions.vsCaseOptionsCapitalize)
' Remove the spaces between the words.
objEditPt.DeleteWhitespace(vsWhitespaceOptions. _
vsWhitespaceOptionsHorizontal)
End Sub
Code
Using System.Windows.Forms;
public void OnConnection(object application,
Extensibility.ext_ConnectMode connectMode, object addInInst,
ref System.Array custom)
{
applicationObject = (_DTE)application;
addInInstance = (AddIn)addInInst;
EditPointExample1((DTE)applicationObject);
}
public void EditPointExample1( DTE dte )
{
TextDocument objTextDoc = null;
EditPoint objEditPt = null; int iCtr = 0;
// Create a new text file.
applicationObject.ItemOperations.NewFile( @"General\Text File",
"", "{00000000-0000-0000-0000-000000000000}" );
// Get a handle to the new document and create an EditPoint.
objTextDoc = ( ( EnvDTE.TextDocument )(
applicationObject.ActiveDocument.Object( "TextDocument" ) ) );
objEditPt = objTextDoc.StartPoint.CreateEditPoint();
// Insert ten lines of text.
for ( iCtr=1; iCtr<=10; iCtr++ )
{
objEditPt.Insert( "This is a test." + "\n");
}
// Replace the eighth word on the third line with a new word.
objEditPt.StartOfDocument();
objEditPt.LineDown( 3 );
objEditPt.WordRight( 3 );
objEditPt.Delete( 4 );
objEditPt.Insert( "raid" );
// Indent a line.
objEditPt.LineDown( 2 );
objEditPt.StartOfLine();
objEditPt.Indent( null, 1 );
// Set some bookmarks.
objEditPt.LineDown( 1 );
// Set the first bookmark.
objEditPt.SetBookmark();
// Set the second bookmark on the next line.
objEditPt.LineDown( 1 );
objEditPt.SetBookmark();
// Go back to the first bookmark.
objEditPt.PreviousBookmark();
// Add some text there.
objEditPt.Insert( "BOOKMARK 1: " );
// Do the same thing at the next bookmark.
objEditPt.NextBookmark();
objEditPt.Insert( "BOOKMARK 2: " );
// Print the current line and character offset in the buffer.
MessageBox.Show( "Line and offset: " + objEditPt.Line);
// Capitalize the third word of the second line.
objEditPt.StartOfDocument();
objEditPt.LineDown( 2 );
objEditPt.WordRight( 3 );
objEditPt.ChangeCase( 4, vsCaseOptions.vsCaseOptionsCapitalize );
// Remove the spaces between the words.
objEditPt.DeleteWhitespace( vsWhitespaceOptions.vsWhitespaceOptionsHorizontal );
}