using System;
using System.Collections.Generic;
namespace ZeroLevel.Services.PartitionStorage
{
///
/// Provides read-write operations in catalog partition
///
/// Key type
/// Type of one input value
/// Type of records aggregate
public interface IStorePartitionAccessor
: IDisposable
{
string GetCatalogPath();
///
/// Has any files
///
int CountDataFiles();
///
/// Remove all files
///
void DropData();
#region API !only after data compression!
///
/// Rebuild indexes
///
void RebuildIndex();
///
/// Find in catalog partition by key
///
StorePartitionKeyValueSearchResult Find(TKey key);
///
/// Find in catalog partition by keys
///
IEnumerable> Find(IEnumerable keys);
IEnumerable> Iterate();
IEnumerable> IterateKeyBacket(TKey key);
#endregion
#region API !only before data compression!
///
/// Save one record
///
void Store(TKey key, TInput value);
///
/// Complete the recording and perform the conversion of the records from
/// (TKey; TInput) to (TKey; TValue)
///
void CompleteAddingAndCompress();
#endregion
}
}