Método AnchorEnumerationContext.ReportChanges
Relata o conjunto de alterações que foram recuperadas durante uma chamada para EnumerateChanges.
Namespace: Microsoft.Synchronization.SimpleProviders
Assembly: Microsoft.Synchronization.SimpleProviders (em microsoft.synchronization.simpleproviders.dll)
Sintaxe
'Declaração
Public Sub ReportChanges ( _
itemChanges As IEnumerable(Of LocalItemChange), _
updatedAnchor As Byte() _
)
'Uso
Dim instance As AnchorEnumerationContext
Dim itemChanges As IEnumerable(Of LocalItemChange)
Dim updatedAnchor As Byte()
instance.ReportChanges(itemChanges, updatedAnchor)
public void ReportChanges (
IEnumerable<LocalItemChange> itemChanges,
byte[] updatedAnchor
)
public:
void ReportChanges (
IEnumerable<LocalItemChange^>^ itemChanges,
array<unsigned char>^ updatedAnchor
)
public void ReportChanges (
IEnumerable<LocalItemChange> itemChanges,
byte[] updatedAnchor
)
public function ReportChanges (
itemChanges : IEnumerable<LocalItemChange>,
updatedAnchor : byte[]
)
Parâmetros
- itemChanges
Uma coleção de objetos LocalItemChange que contêm metadados sobre alterações em itens na réplica local.
- updatedAnchor
Uma matriz de bytes que representa uma âncora de enumeração, como um carimbo de data/hora.
Exceções
Tipo de exceção | Condição |
---|---|
ReportItemsAndAutodetectDeletes foi chamado na mesma sessão. |
Exemplo
O código de exemplo a seguir mostra que o objeto AnchorEnumerationContext que está sendo passado para o método EnumerateChanges e o método ReportChanges que está sendo chamado no objeto do contexto. Para exibir esse código no contexto de um aplicativo completo, consulte o aplicativo "Sync101 using Simple Sync Provider"
disponível no Sync Framework SDK e em Code Gallery.
public override void EnumerateChanges(byte[] anchor, AnchorEnumerationContext context)
{
List<LocalItemChange> itemChanges = new List<LocalItemChange>();
int startIndex = -1;
if (anchor != null)
{
startIndex = _store.Changes.IndexOfKey(BitConverter.ToUInt64(anchor, 0));
}
for (int i = startIndex + 1; i < _store.Changes.Count; i++)
{
itemChanges.Add(_store.Changes.Values[i]);
}
// If the anchor is corrupt or out of date we could revert back to
// full enumeration mode for this session, and enumerate all items.
// This is done by calling context.ReportItemsAndAutodetectDeletes.
context.ReportChanges(itemChanges, _store.GetAnchor());
}
Public Overrides Sub EnumerateChanges(ByVal anchor As Byte(), ByVal context As AnchorEnumerationContext)
Dim itemChanges As New List(Of LocalItemChange)()
Dim startIndex As Integer = -1
If anchor IsNot Nothing Then
startIndex = _store.Changes.IndexOfKey(BitConverter.ToUInt64(anchor, 0))
End If
For i As Integer = startIndex + 1 To _store.Changes.Count - 1
itemChanges.Add(_store.Changes.Values(i))
Next
' If the anchor is corrupt or out of date we could revert back to
' full enumeration mode for this session, and enumerate all items.
' This is done by calling context.ReportItemsAndAutodetectDeletes.
context.ReportChanges(itemChanges, _store.GetAnchor())
End Sub
Consulte também
Referência
Classe AnchorEnumerationContext
Membros AnchorEnumerationContext
Namespace Microsoft.Synchronization.SimpleProviders