Use when you have a written implementation plan to execute in a separate session with review checkpoints
npx skills add hzqst/CS2_VibeSignatures --skill "get-vtable-index"
Install specific skill from multi-skill repository
# Description
|
# SKILL.md
name: get-vtable-index
description: |
Find a function's vtable offset and index using IDA Pro MCP. Use this skill when you have a function address and need to determine its position in a vtable by iterating through vtable entries.
Triggers: vtable index, vftable offset, virtual function table position, find function in vtable
Get VTable Index
Find a function's position (offset and index) within a vtable by iterating through vtable entries.
Prerequisites
- Function address (from decompilation or xrefs)
- ClassName (to get vtable via
get-vtable-addressskill) - platform (either
windowsorlinux, depending on the binary we are analyzing)
Method
1. Load vtable YAML and find function index:
ALWAYS first check if {ClassName}_vtable.{platform}.yaml exists beside the binary, then search for the function in vtable_entries:
```python
mcp__ida-pro-mcp__py_eval code="""
import idaapi
import yaml
import os
# === REQUIRED: Replace these values ===
class_name = "
func_addr =
# ======================================
input_file = idaapi.get_input_file_path()
dir_path = os.path.dirname(input_file)
platform = 'windows' if input_file.endswith('.dll') else 'linux'
yaml_path = os.path.join(dir_path, f"{class_name}_vtable.{platform}.yaml")
if not os.path.exists(yaml_path):
print(f"ERROR: Required file {class_name}_vtable.{platform}.yaml not found.")
print(f"Expected path: {yaml_path}")
print(f"Please run /find-{class_name}_vtable first to generate the vtable YAML file.")
else:
with open(yaml_path, 'r', encoding='utf-8') as f:
data = yaml.safe_load(f)
vtable_entries = data.get('vtable_entries', {})
vtable_va = data.get('vtable_va')
ptr_size = 8 if idaapi.inf_is_64bit() else 4
for idx, entry in vtable_entries.items():
# Handle both int and hex string formats
i = int(idx) if isinstance(idx, str) else idx
entry_addr = int(entry, 16) if isinstance(entry, str) else entry
if entry_addr == func_addr:
offset = i * ptr_size
print(f"Found at vtable offset: {hex(offset)}, index: {i}")
print(f"vtable_va: {hex(vtable_va) if isinstance(vtable_va, int) else vtable_va}")
break
else:
print(f"Function {hex(func_addr)} not found in {class_name} vtable entries!")
"""
```
Replace:
- <ClassName> with the target class name (e.g., CCSPlayerPawn)
- <FUNC_ADDRESS> with the target function address
IMPORTANT: Use the function entry address. VTables store pointers to the function start; string xrefs often land in the middle of a function. If you only have an address inside the function, resolve the real entry first:
python
mcp__ida-pro-mcp__py_eval code="""
import idaapi
addr_inside_func = <ADDRESS_INSIDE_FUNCTION>
f = idaapi.get_func(addr_inside_func)
print(f"Function entry: {hex(f.start_ea)}" if f else "Not inside a function")
"""
2. Continue with the unfinished tasks
If we are called by a task from a task list / parent SKILL, restore and continue with the unfinished tasks.
Formulas
vfunc_offset = index × ptr_size(ptr_size = 8 for 64-bit, 4 for 32-bit)vfunc_index = offset / ptr_size, and is the index of the entry invtable_entries.
# Supported AI Coding Agents
This skill is compatible with the SKILL.md standard and works with all major AI coding agents:
Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.