Поделиться через


UndoContext.Open - метод

Запускает новую операцию отмены.

Пространство имен:  EnvDTE
Сборка:  EnvDTE (в EnvDTE.dll)

Синтаксис

'Декларация
Sub Open ( _
    Name As String, _
    Strict As Boolean _
)
void Open(
    string Name,
    bool Strict
)
void Open(
    [InAttribute] String^ Name, 
    [InAttribute] bool Strict
)
abstract Open : 
        Name:string * 
        Strict:bool -> unit 
function Open(
    Name : String, 
    Strict : boolean
)

Параметры

  • Name
    Тип: System.String
    Обязательный.Представляет имя процедуры, для которой следует предоставить контекст отмены.
  • Strict
    Тип: System.Boolean
    Необязательный.Показывает, является ли компоновка стека отмены строгой.Значение по умолчанию – False.

Заметки

Если объект UndoContext уже открыт при выполнении метода Open, возникает ошибка.

Если компоновка стека отмены является строгой, все связанные стеки отмены одного и того же уровня должны отменяться все вместе или не отменяться вообще. Строгая связанная операция отмены обычно необходима для одновременного изменения текста в нескольких файлах, например в файле заголовка и файле Visual C++. Это модель, используемая в Visual Studio. Дополнительные сведения об отмене связывания стека см. в описании метода OpenLinkedUndo.

Примеры

Sub OpenExample()
   ' Before running, select text in an open document.
   Dim txtSel As TextSelection
   Dim strTS As String, boolWasOpen As Boolean
   txtSel = DTE.ActiveDocument.Selection
   strTS = txtSel.Text

   ' Check to see if UndoContext object is already open.
   If DTE.UndoContext.IsOpen = True Then
      boolWasOpen = True
   Else
      ' Open the UndoContext object to track changes.
      DTE.UndoContext.Open("RemoveNewLines", False)
   End If

   ' Perform search for newline characters and remove them.
   If strTS <> "" Then
      txtSel.Delete()
      strTS = Replace(strTS, vbNewLine, "", Compare:=vbTextCompare)
      txtSel.Insert(strTS)
   End If

   ' If UndoContext was already open, don't close it.
   If boolWasOpen = False Then
      ' Close the UndoContext object to commit the changes.
      DTE.UndoContext.Close()
   End If
End Sub

Безопасность платформы .NET Framework

См. также

Ссылки

UndoContext Интерфейс

EnvDTE - пространство имен