IDiaEnumFrameData
データ ソースに含まれているさまざまなフレームデータ要素を列挙します。
構文
IDiaEnumFrameData : IUnknown
Vtable 順序のメソッド
次の表に、IDiaEnumFrameData
のメソッドを示します。
メソッド | 説明 |
---|---|
IDiaEnumFrameData::get__NewEnum | この列挙子の IEnumVARIANT Interface バージョンを取得します。 |
IDiaEnumFrameData::get_Count | フレーム データ要素の数を取得します。 |
IDiaEnumFrameData::Item | インデックスを使用してフレーム データ要素を取得します。 |
IDiaEnumFrameData::Next | 列挙シーケンス内の指定された数のフレーム データ要素を取得します。 |
IDiaEnumFrameData::Skip | 列挙シーケンス内の指定された数のフレーム データ要素をスキップします。 |
IDiaEnumFrameData::Reset | 列挙シーケンスを先頭にリセットします。 |
IDiaEnumFrameData::Clone | 現在の列挙子と同じ列挙状態を含む列挙子を作成します。 |
IDiaEnumFrameData::frameByRVA | 相対仮想アドレス (RVA) でフレームを返します。 |
IDiaEnumFrameData::frameByVA | 仮想アドレス (VA) でフレームを返します。 |
解説
呼び出し元に関する注意事項
このインターフェイスは IDiaSession::getEnumTables メソッドから取得します。 詳細についての例を参照してください。
例
この例では、IDiaEnumFrameData
インターフェイスを取得する方法 (GetEnumFrameData
関数) と使用する方法 (ShowFrameData
関数) を示します。 PrintFrameData
関数の例については、IDiaFrameData インターフェイスを参照してください。
IDiaEnumFrameData* GetEnumFrameData(IDiaSession *pSession)
{
IDiaEnumFrameData* pUnknown = NULL;
REFIID iid = __uuidof(IDiaEnumFrameData);
IDiaEnumTables* pEnumTables = NULL;
IDiaTable* pTable = NULL;
ULONG celt = 0;
if (pSession->getEnumTables(&pEnumTables) != S_OK)
{
wprintf(L"ERROR - GetTable() getEnumTables\n");
return NULL;
}
while (pEnumTables->Next(1, &pTable, &celt) == S_OK && celt == 1)
{
// There is only one table that matches the given iid
HRESULT hr = pTable->QueryInterface(iid, (void**)&pUnknown);
pTable->Release();
if (hr == S_OK)
{
break;
}
}
pEnumTables->Release();
return pUnknown;
}
void ShowFrameData(IDiaSession *pSession)
{
IDiaEnumFrameData* pEnumFrameData = GetEnumFrameData(pSession);
if (pEnumFrameData != NULL)
{
IDiaFrameData* pFrameData;
ULONG celt = 0;
while(pEnumFrameData->Next(1, &pFrameData, &celt) == S_OK &&
celt == 1)
{
PrintFrameData(pFrameData);
pFrameData->Release();
}
pEnumFrameData->Release();
}
}
要件
ヘッダー: Dia2.h
ライブラリ: diaguids.lib
DLL: msdia80.dll