Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Crawler Summary
Rope-first workflow for ANY mechanical Python rename/move (functions/methods/classes/variables/modules/packages), updating imports/references via scripts/rope_refactor.py; use even for small renames; only fallback if rope fails/dynamic imports. --- name: Python Rope Refactor description: Rope-first workflow for ANY mechanical Python rename/move (functions/methods/classes/variables/modules/packages), updating imports/references via scripts/rope_refactor.py; use even for small renames; only fallback if rope fails/dynamic imports. --- Python Rope Refactor Default policy (rope-first) When the user asks for mechanical Python refactors like **move module**, **ren Capability contract not published. No trust telemetry is available yet. 37 GitHub stars reported by the source. Last updated 4/15/2026.
Freshness
Last checked 4/15/2026
Best For
Python Rope Refactor is best for be, the, miss workflows where OpenClaw compatibility matters.
Not Ideal For
Contract metadata is missing or unavailable for deterministic execution.
Evidence Sources Checked
editorial-content, GITHUB OPENCLEW, runtime-metrics, public facts pack
Rope-first workflow for ANY mechanical Python rename/move (functions/methods/classes/variables/modules/packages), updating imports/references via scripts/rope_refactor.py; use even for small renames; only fallback if rope fails/dynamic imports. --- name: Python Rope Refactor description: Rope-first workflow for ANY mechanical Python rename/move (functions/methods/classes/variables/modules/packages), updating imports/references via scripts/rope_refactor.py; use even for small renames; only fallback if rope fails/dynamic imports. --- Python Rope Refactor Default policy (rope-first) When the user asks for mechanical Python refactors like **move module**, **ren
Public facts
5
Change events
1
Artifacts
0
Freshness
Apr 15, 2026
Capability contract not published. No trust telemetry is available yet. 37 GitHub stars reported by the source. Last updated 4/15/2026.
Trust score
Unknown
Compatibility
OpenClaw
Freshness
Apr 15, 2026
Vendor
Brian Yu
Artifacts
0
Benchmarks
0
Last release
Unpublished
Key links, install path, and a quick operational read before the deeper crawl record.
Summary
Capability contract not published. No trust telemetry is available yet. 37 GitHub stars reported by the source. Last updated 4/15/2026.
Setup snapshot
git clone https://github.com/brian-yu/python-rope-refactor.gitSetup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.
Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.
Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.
Vendor
Brian Yu
Protocol compatibility
OpenClaw
Adoption signal
37 GitHub stars
Handshake status
UNKNOWN
Crawlable docs
6 indexed pages on the official domain
Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.
Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.
Extracted files
0
Examples
6
Snippets
0
Languages
typescript
Parameters
bash
uv run scripts/rope_refactor.py \ rename-symbol \ --project-root . \ --auto-project-root \ --auto-scan-roots \ --file path/to/file.py \ --symbol OldName \ --context class \ --new-name NewName \ --dry-run
bash
uv run scripts/rope_refactor.py --help uv run scripts/rope_refactor.py move-module --help
bash
uv run scripts/rope_refactor.py ... --apply git diff
bash
uv run scripts/rope_refactor.py \ move-module \ --project-root . \ --auto-project-root \ --src pkg/old_mod.py \ --dest-package pkg.newpkg \ --dry-run uv run scripts/rope_refactor.py \ move-module \ --project-root . \ --auto-project-root \ --src pkg/old_mod.py \ --dest-package pkg.newpkg \ --apply
bash
uv run scripts/rope_refactor.py \ rename-module \ --project-root . \ --auto-project-root \ --src pkg/foo.py \ --new-name bar \ --dry-run uv run scripts/rope_refactor.py \ rename-module \ --project-root . \ --auto-project-root \ --src pkg/foo.py \ --new-name bar \ --apply
bash
uv run scripts/rope_refactor.py \ rename-symbol \ --project-root . \ --auto-project-root \ --file pkg/models.py \ --symbol OldName \ --context class \ --new-name NewName \ --dry-run
Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB OPENCLEW
Editorial quality
ready
Rope-first workflow for ANY mechanical Python rename/move (functions/methods/classes/variables/modules/packages), updating imports/references via scripts/rope_refactor.py; use even for small renames; only fallback if rope fails/dynamic imports. --- name: Python Rope Refactor description: Rope-first workflow for ANY mechanical Python rename/move (functions/methods/classes/variables/modules/packages), updating imports/references via scripts/rope_refactor.py; use even for small renames; only fallback if rope fails/dynamic imports. --- Python Rope Refactor Default policy (rope-first) When the user asks for mechanical Python refactors like **move module**, **ren
When the user asks for mechanical Python refactors like move module, rename module, or rename class/function/symbol, default to running rope via uv run scripts/rope_refactor.py rather than manually editing imports/usages.
Workflow:
--dry-run--applygit diffOnly fall back to manual edits when rope fails or the code uses dynamic/string-based imports.
Use this skill when you need reliable, mechanical Python refactors (especially in larger codebases) and want imports/usages updated automatically.
This skill provides a small CLI wrapper around rope refactorings with a safe workflow.
uv is installed.Tip: in large monorepos, prefer --auto-project-root (and optionally --auto-scan-roots) to avoid rope scanning the entire repo.
Example (paths can be relative to repo root; the tool will re-root them):
uv run scripts/rope_refactor.py \
rename-symbol \
--project-root . \
--auto-project-root \
--auto-scan-roots \
--file path/to/file.py \
--symbol OldName \
--context class \
--new-name NewName \
--dry-run
If roots are too narrow (missed references):
--apply, run rg for the old symbol/module name(s) to confirm no leftovers.--scan-roots <top-level-package> (e.g. --scan-roots responsesapi)--scan-roots/--auto-scan-roots to scan the whole project root (slow but complete)uv run scripts/rope_refactor.py --help
uv run scripts/rope_refactor.py move-module --help
uv run scripts/rope_refactor.py ... --apply
git diff
Example: move pkg/old_mod.py into the pkg/newpkg package.
Destination package must exist on disk and include __init__.py (rope requires a real package folder).
uv run scripts/rope_refactor.py \
move-module \
--project-root . \
--auto-project-root \
--src pkg/old_mod.py \
--dest-package pkg.newpkg \
--dry-run
uv run scripts/rope_refactor.py \
move-module \
--project-root . \
--auto-project-root \
--src pkg/old_mod.py \
--dest-package pkg.newpkg \
--apply
Example: rename pkg/foo.py to pkg/bar.py (module name foo -> bar).
uv run scripts/rope_refactor.py \
rename-module \
--project-root . \
--auto-project-root \
--src pkg/foo.py \
--new-name bar \
--dry-run
uv run scripts/rope_refactor.py \
rename-module \
--project-root . \
--auto-project-root \
--src pkg/foo.py \
--new-name bar \
--apply
Rope renames based on a precise cursor/offset into a file.
This wrapper lets you target the symbol precisely:
--offset (most precise)--pattern + optional --occurrence and --group--symbol + --context class|def|any (builds a safer pattern when --pattern is omitted)Example: rename a class OldName -> NewName using --symbol targeting (recommended):
uv run scripts/rope_refactor.py \
rename-symbol \
--project-root . \
--auto-project-root \
--file pkg/models.py \
--symbol OldName \
--context class \
--new-name NewName \
--dry-run
Example: rename a class OldName -> NewName using a pattern:
uv run scripts/rope_refactor.py \
rename-symbol \
--project-root . \
--auto-project-root \
--file pkg/models.py \
--new-name NewName \
--pattern 'class\\s+OldName\\b' \
--dry-run
uv run scripts/rope_refactor.py \
rename-symbol \
--project-root . \
--auto-project-root \
--file pkg/models.py \
--new-name NewName \
--pattern 'class\\s+OldName\\b' \
--apply
Extract a line range into a new function:
uv run scripts/rope_refactor.py \
extract-function \
--project-root . \
--auto-project-root \
--file pkg/mod.py \
--start-line 10 \
--end-line 25 \
--new-name helper_fn \
--dry-run
Extract a line range into a method:
uv run scripts/rope_refactor.py \
extract-method \
--project-root . \
--auto-project-root \
--file pkg/mod.py \
--start-line 10 \
--end-line 25 \
--new-name _helper \
--dry-run
Inline a variable at a specific definition site using --symbol targeting:
uv run scripts/rope_refactor.py \
inline-variable \
--project-root . \
--auto-project-root \
--file pkg/mod.py \
--symbol TEMP \
--context any \
--dry-run
uv run scripts/rope_refactor.py \
organize-imports \
--project-root . \
--auto-project-root \
--roots pkg \
--dry-run
Create a JSON file (list of ops or {"ops": [...]}), then run:
cat > /tmp/rope_ops.json <<'JSON'
[
{"op": "rename-module", "src": "pkg/foo.py", "new_name": "bar"},
{"op": "move-module", "src": "pkg/bar.py", "dest_package": "pkg.subpkg"},
{"op": "rename-symbol", "file": "pkg/subpkg/bar.py", "symbol": "OldClass", "context": "class", "new_name": "NewClass"},
{"op": "organize-imports", "roots": ["pkg"]}
]
JSON
uv run scripts/rope_refactor.py \
batch \
--project-root . \
--auto-project-root \
--map /tmp/rope_ops.json \
--dry-run
--dry-run first; always review git diff after --apply.importlib.import_module("pkg.old_mod")"pkg.mod:Class"# old_mod.py
from pkg.newpkg.old_mod import SomeName
__all__ = ["SomeName"]
If rope fails due to version/API differences or code is too dynamic:
rg search + update imports manuallyMachine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
missing
Auth
None
Streaming
No
Data region
Unspecified
Protocol support
Requires: none
Forbidden: none
Guardrails
Operational confidence: low
curl -s "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/snapshot"
curl -s "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/contract"
curl -s "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/trust"
Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.
Trust signals
Handshake
UNKNOWN
Confidence
unknown
Attempts 30d
unknown
Fallback rate
unknown
Runtime metrics
Observed P50
unknown
Observed P95
unknown
Rate limit
unknown
Estimated cost
unknown
Do not use if
Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.
Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.
Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Rank
70
AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs
Traction
No public download signal
Freshness
Updated 5d ago
Rank
70
Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!
Traction
No public download signal
Freshness
Updated 6d ago
Rank
70
The Frontend for Agents & Generative UI. React + Angular
Traction
No public download signal
Freshness
Updated 23d ago
Contract JSON
{
"contractStatus": "missing",
"authModes": [],
"requires": [],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": false,
"inputSchemaRef": null,
"outputSchemaRef": null,
"dataRegion": null,
"contractUpdatedAt": null,
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/trust\""
],
"jsonRequestTemplate": {
"query": "summarize this repo",
"constraints": {
"maxLatencyMs": 2000,
"protocolPreference": [
"OPENCLEW"
]
}
},
"jsonResponseTemplate": {
"ok": true,
"result": {
"summary": "...",
"confidence": 0.9
},
"meta": {
"source": "GITHUB_OPENCLEW",
"generatedAt": "2026-04-17T01:37:38.947Z"
}
},
"retryPolicy": {
"maxAttempts": 3,
"backoffMs": [
500,
1500,
3500
],
"retryableConditions": [
"HTTP_429",
"HTTP_503",
"NETWORK_TIMEOUT"
]
}
}Trust JSON
{
"status": "unavailable",
"handshakeStatus": "UNKNOWN",
"verificationFreshnessHours": null,
"reputationScore": null,
"p95LatencyMs": null,
"successRate30d": null,
"fallbackRate": null,
"attempts30d": null,
"trustUpdatedAt": null,
"trustConfidence": "unknown",
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Capability Matrix
{
"rows": [
{
"key": "OPENCLEW",
"type": "protocol",
"support": "unknown",
"confidenceSource": "profile",
"notes": "Listed on profile"
},
{
"key": "be",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "the",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "miss",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
}
],
"flattenedTokens": "protocol:OPENCLEW|unknown|profile capability:be|supported|profile capability:the|supported|profile capability:miss|supported|profile"
}Facts JSON
[
{
"factKey": "docs_crawl",
"category": "integration",
"label": "Crawlable docs",
"value": "6 indexed pages on the official domain",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Brian Yu",
"href": "https://github.com/brian-yu/python-rope-refactor",
"sourceUrl": "https://github.com/brian-yu/python-rope-refactor",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-04-15T04:13:30.828Z",
"isPublic": true
},
{
"factKey": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "OpenClaw",
"href": "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-04-15T04:13:30.828Z",
"isPublic": true
},
{
"factKey": "traction",
"category": "adoption",
"label": "Adoption signal",
"value": "37 GitHub stars",
"href": "https://github.com/brian-yu/python-rope-refactor",
"sourceUrl": "https://github.com/brian-yu/python-rope-refactor",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-04-15T04:13:30.828Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/brian-yu-python-rope-refactor/trust",
"sourceType": "trust",
"confidence": "medium",
"observedAt": null,
"isPublic": true
}
]Change Events JSON
[
{
"eventType": "docs_update",
"title": "Docs refreshed: Sign in to GitHub · GitHub",
"description": "Fresh crawlable documentation was indexed for the official domain.",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
}
]Sponsored
Ads related to Python Rope Refactor and adjacent AI workflows.