|
2 | 2 |
|
3 | 3 | Full release notes with details on each version: [GitHub Releases](https://github.com/safishamsi/graphify/releases) |
4 | 4 |
|
| 5 | +## 0.4.23 (2026-04-18) |
| 6 | + |
| 7 | +- Fix: stale skill version warning persists after running `graphify install` when multiple platforms were previously installed — `graphify install` now refreshes `.graphify_version` in all other known skill directories so the warning clears across the board (#178) |
| 8 | +- Fix: `.html` files silently skipped during detection — added `.html` to `DOC_EXTENSIONS`; HTML pages, docs, and web project content now indexed correctly (#260) |
| 9 | +- Fix: `_rebuild_code` (watch/update/hook) fails entirely on graphs > 5000 nodes because `to_html` raises `ValueError` — wrapped in its own try/except so `graph.json` and `GRAPH_REPORT.md` always land; stale `graph.html` from a previous smaller run is removed (#432) |
| 10 | +- Fix: Go stdlib imports (e.g. `"context"`) produced `imports_from` edges pointing at local files of the same basename — Go import node IDs now prefixed `go_pkg_` using the full import path, eliminating false cycle-dependency pairs (#431) |
| 11 | + |
| 12 | +## 0.4.22 (2026-04-18) |
| 13 | + |
| 14 | +- Fix: AST cache written to `src/graphify-out/cache/` instead of project root when all code files share a common prefix like `src/` — `extract()` now called with explicit `cache_root=watch_path` in `_rebuild_code` and `cache_root=Path('.')` in the Codex skill AST step (#429) |
| 15 | +- Fix: `.mdx` files silently skipped during detection — added `.mdx` to `DOC_EXTENSIONS` in `detect.py`; MDX-based corpora (Next.js, Docusaurus, Astro) now indexed correctly (#428) |
| 16 | + |
| 17 | +## 0.4.21 (2026-04-17) |
| 18 | + |
| 19 | +- Fix: `graphify cluster-only` crashed with `KeyError: 'total_files'` in `report.py` — cluster-only skips detection so the stats dict was empty; now passes a `warning` key so the report skips the file-stats section (#422) |
| 20 | +- Fix: `/graphify --update` dropped all existing graph nodes — the merge block built a correct in-memory `G_existing` but never wrote it back to `.graphify_extract.json`, so Step 4 rebuilt from the new-extraction-only file; merged result is now serialized back before Step 4 runs (#423) |
| 21 | + |
| 22 | +## 0.4.20 (2026-04-17) |
| 23 | + |
| 24 | +- Fix: JS/MJS `imports_from` edges were silently dropped for files that use `../subdir/file.mjs` style imports — `Path.parent / raw` left `..` segments unnormalized, so the generated target ID didn't match the actual file node ID. Fixed with `os.path.normpath` (#414) |
| 25 | +- Fix: `graphify update .` and `graphify cluster-only` now generate `graph.html` alongside `graph.json` and `GRAPH_REPORT.md` — previously only the skill generated the interactive HTML (#418) |
| 26 | + |
| 27 | +## 0.4.19 (2026-04-17) |
| 28 | + |
| 29 | +- Fix: AST and semantic extraction no longer produce mismatched node IDs — `build_from_json` now normalises IDs before dropping edges, so edges survive when the LLM generates slightly different casing or punctuation than the AST extractor (#390) |
| 30 | +- Fix: cross-file call resolution extended to Go, Rust, Zig, PowerShell, and Elixir — unresolved callees are now saved as `raw_calls` and resolved globally in a post-pass, matching existing behaviour for Python, Swift, Java, C#, Kotlin, Scala, Ruby, and PHP (#298) |
| 31 | +- Fix: Windows `graphify-out/graphify-out` nesting bug — `cache_dir` and `_rebuild_code` in watch.py now call `.resolve()` on the root path, preventing a nested output directory when graphify is run from a subdirectory (#410) |
| 32 | +- Fix: `graphify hook install` now respects `core.hooksPath` git config (used by Husky and similar tools) — hooks are written to the configured path instead of always `.git/hooks` (#401) |
| 33 | +- Fix: Kiro skill YAML frontmatter — `description` value is now quoted and colons replaced with dashes, preventing a parse error in Kiro's YAML loader (#385) |
| 34 | +- Docs: added Windows PATH tip (`%APPDATA%\Python\PythonXY\Scripts`) and macOS pipx tip (`pipx ensurepath`) to the install section (#413) |
| 35 | +- Docs: added team workflow section — committing `graphify-out/`, `.graphifyignore` usage, and recommended `.gitignore` additions (#369) |
| 36 | + |
| 37 | +## 0.4.16 (2026-04-16) |
| 38 | + |
| 39 | +- Fix: graphify watch crashed on all platforms with NameError because import sys was missing from watch.py (#386, #394) |
| 40 | +- Fix: .mjs files were detected but produced 0 nodes — added .mjs to the AST extractor dispatch table (#387) |
| 41 | +- Fix: llm.py excluded from the published wheel (local benchmarking file, not part of the public API) (#391) |
| 42 | + |
| 43 | +## 0.4.15 (2026-04-15) |
| 44 | + |
| 45 | +- Feat: VS Code Copilot Chat support — `graphify vscode install` installs a Python-only skill (works on Windows PowerShell) and writes `.github/copilot-instructions.md` for always-on graph context (#206) |
| 46 | +- Fix: OpenCode plugin path used backslashes on Windows causing duplicate entries in `opencode.json` — now uses forward slashes via `.as_posix()` (#378) |
| 47 | +- Fix: Gemini CLI on Windows now installs skill to `~/.agents/skills/` (higher priority) instead of `~/.gemini/skills/` (#368) |
| 48 | +- Fix: `.mjs` and `.ejs` files now recognised by the AST extractor as JavaScript (#365, #372) |
| 49 | +- Fix: `god_nodes()` field renamed from `edges` to `degree` for clarity — updated in report, wiki, serve, and all tests (#375) |
| 50 | +- Fix: macOS `graphify watch` now uses `PollingObserver` by default to avoid missed events with FSEvents (#373) |
| 51 | + |
| 52 | +## 0.4.14 (2026-04-15) |
| 53 | + |
| 54 | +- Fix: cross-file call edges now emitted for all languages (Swift, Go, Rust, Java, C#, Kotlin, Scala, Ruby, PHP, and others) — previously only Python had cross-file resolution; unresolved call sites are now saved per file and resolved against a global label map in a post-pass (#348) |
| 55 | +- Fix: PHP extractor now handles `scoped_call_expression` (static method calls like `Helper::format()`) and `class_constant_access_expression` (enum/constant references like `Status::ACTIVE`) — both were silently dropped before (#230, #232) |
| 56 | +- Fix: `--wiki` flag now runs `to_wiki()` as Step 6b in the skill pipeline before the cleanup step — community labels are available and the wiki is written to `graphify-out/wiki/` (#229, #354) |
| 57 | +- Fix: `graphify install --platform opencode` now also installs the `.opencode/plugins/graphify.js` plugin, matching what `graphify opencode install` does (#356) |
| 58 | +- Fix: `extract()` accepts explicit `cache_root` parameter so subdirectory runs no longer write cache to `<subdir>/graphify-out/cache/` (#350) |
| 59 | +- Fix: `os.replace` in cache writer falls back to `shutil.copy2` on `PermissionError` (Windows WinError 5) (#287) |
| 60 | +- Fix: `graphify update` exits with code 1 on rebuild failure instead of silently returning (#287) |
| 61 | +- Fix: `CLAUDE.md`, Cursor, and Antigravity templates now use `graphify update .` instead of hardcoded `python3 -c` invocation (#287) |
| 62 | +- Fix: `skill-kiro.md` added to `pyproject.toml` package-data — `graphify kiro install` was failing on fresh pip installs (#352) |
| 63 | +- Fix: `betweenness_centrality` in `suggest_questions` uses `k=100` approximate sampling for graphs over 1000 nodes; `edge_betweenness_centrality` returns early for graphs over 5000 nodes (#341) |
| 64 | + |
| 65 | +## 0.4.13 (2026-04-14) |
| 66 | + |
| 67 | +- Add: Verilog/SystemVerilog support — `.v` and `.sv` files extracted via tree-sitter-verilog (modules, functions, tasks, package imports, module instantiations with `instantiates` edges) (#325) |
| 68 | +- Fix: hyperedge polygons render correctly on HiDPI/Retina displays — `afterDrawing` callback ctx is now used directly (already in network coordinate space), removing the double-applied transform and incorrect `canvas.width/2` DPR anchor (#334) |
| 69 | +- Fix: AGENTS.md and GEMINI.md rebuild rule now uses `graphify update .` instead of hardcoded `python3 -c "..."` — correct Python is resolved through the graphify binary, no more interpreter mismatches in Nix/pipx/uv environments (#324) |
| 70 | +- Fix: `graphify query` and `graphify explain` no longer crash with `AttributeError` when a node has `label: null` — all `.get("label", "")` calls guarded with `or ""` to handle explicit null values (#323) |
| 71 | + |
| 72 | +## 0.4.12 (2026-04-13) |
| 73 | + |
| 74 | +- Add: Kiro IDE/CLI support — `graphify kiro install` writes `.kiro/skills/graphify/SKILL.md` (invoked via `/graphify`) and `.kiro/steering/graphify.md` (`inclusion: always` — always-on context before every conversation) (#319, #321) |
| 75 | +- Fix: cache `file_hash()` now uses the path relative to project root instead of the resolved absolute path — cache entries are now portable across machines, CI runners, and different checkout directories (#311) |
| 76 | + |
| 77 | +## 0.4.11 (2026-04-13) |
| 78 | + |
| 79 | +- Fix: `graphify query` no longer crashes with `ValueError` on MultiGraph graphs — `G.edges[u, v]` replaced with `G[u][v]` + MultiGraph guard (#305) |
| 80 | +- Fix: `graphify query` no longer crashes with `AttributeError: 'NoneType' has no attribute 'lower'` when a node has a null `source_file` (#307) |
| 81 | +- Fix: MCP server launched from a different directory now correctly derives the `graphify-out` base from the absolute path provided, instead of CWD (#309) |
| 82 | +- Fix: `.graphifyignore` patterns from a parent directory now fire correctly when graphify is run on a subfolder — patterns are matched against paths relative to both the scan root and the `.graphifyignore`'s anchor directory (#303) |
| 83 | + |
| 84 | +## 0.4.10 (2026-04-13) |
| 85 | + |
| 86 | +- Fix: `graphify install --platform cursor` no longer crashes — passes `Path(".")` to `_cursor_install` (#281) |
| 87 | +- Fix: `_agents_uninstall` now only removes the OpenCode plugin when uninstalling the `opencode` platform — other platforms were incorrectly having their OpenCode plugin stripped (#276) |
| 88 | +- Fix: misleading comment in query `--graph` path handler removed (#278) |
| 89 | +- Fix: `skill-codex.md` — `wait` → `wait_agent` (correct Codex tool name) (#273) |
| 90 | +- Add: `svg = ["matplotlib"]` optional extra in pyproject.toml; `matplotlib` added to `[all]` extra (#288) |
| 91 | +- Fix: `graspologic` dependency now has `python_version < '3.13'` env marker in `leiden` and `all` extras — prevents install failures on Python 3.13+ (#290) |
| 92 | +- Add: Dart/Flutter support — `.dart` files extracted via regex (classes, mixins, functions, imports); added to `CODE_EXTENSIONS` (#292) |
| 93 | +- Add: `norm_label` field written at build time in `to_json()` for diacritic-insensitive search; `_score_nodes` and `_find_node` in `serve.py` use `norm_label` with Unicode NFKD normalization fallback (#293) |
| 94 | +- Add: Hermes Agent platform support — `graphify hermes install` writes skill to `~/.hermes/skills/graphify/SKILL.md` and AGENTS.md (#251) |
| 95 | +- Add: PHP extractor now captures static property access (`Foo::$bar`) as `uses_static_prop` edges (#234) |
| 96 | +- Add: PHP extractor now captures `config()` helper calls as `uses_config` edges pointing to the first config key segment (#236) |
| 97 | +- Add: PHP extractor now captures service container bindings (`bind`, `singleton`, `scoped`, `instance`) as `bound_to` edges (#238) |
| 98 | +- Add: PHP extractor now captures `$listen` / `$subscribe` event listener arrays as `listened_by` edges (#240) |
| 99 | +- Add: `prune_dangling_edges()` utility in `export.py` — removes edges whose source/target is not in the node set (#294) |
| 100 | +- Fix: Antigravity install injects YAML frontmatter into skill file for native tool discovery; rules now include MCP navigation hint; prints MCP config snippet (#268) |
| 101 | +- Fix: Windows hook tests now use platform-aware assertions instead of POSIX executable bit checks (#279) |
| 102 | +- Add: CLI commands `path`, `explain`, `add`, `watch`, `update`, `cluster-only` now work as bare terminal commands (not just AI skill invocations) — documented in `--help` output (#277) |
| 103 | + |
| 104 | +## 0.4.8 (2026-04-12) |
| 105 | + |
| 106 | +- Fix: platform skill files (aider, codex, opencode, claw, droid, copilot, windows) no longer contain Claude-specific language — references to "Claude" as the AI model replaced with platform-agnostic wording (#272) |
| 107 | + |
| 108 | +## 0.4.7 (2026-04-12) |
| 109 | + |
| 110 | +- Fix: `watch` semantic edge preservation was always empty — `graph.json` uses `links` key but code read `edges` (#269) |
| 111 | +- Fix: `graphify claw install` now writes to `.openclaw/` (correct OpenClaw directory) instead of `.claw/` (#208) |
| 112 | +- Add: Blade template support — `@include`, `<livewire:>` components, and `wire:click` bindings extracted from `.blade.php` files (#242) |
| 113 | +- Docs: WSL/Linux MCP setup note — package name is `graphifyy`, use `.venv/bin/python3` in `.mcp.json` (#250) |
| 114 | + |
| 115 | +## 0.4.6 (2026-04-12) |
| 116 | + |
| 117 | +- Add: Google Antigravity support — `graphify antigravity install` writes `.agent/rules/graphify.md` (always-on rules) and `.agent/workflows/graphify.md` (`/graphify` slash command) (#203, #199, #53) |
| 118 | + |
| 119 | +## 0.4.5 (2026-04-12) |
| 120 | + |
| 121 | +- Fix: MCP server no longer crashes with `ValidationError` on blank lines sent between JSON messages by some clients (#201) |
| 122 | + |
| 123 | +## 0.4.4 (2026-04-12) |
| 124 | + |
| 125 | +- Fix: `watch` now preserves INFERRED/AMBIGUOUS edges (code↔doc rationale links) across rebuilds — previously all cross-type edges were dropped (#261) |
| 126 | +- Fix: Codex hook no longer emits `permissionDecision:allow` which codex-cli 0.120.0 rejects (#249) |
| 127 | +- Fix: Common lockfiles (`package-lock.json`, `yarn.lock`, `Cargo.lock`, etc.) are now skipped during detection, preventing token drain on large JS/Rust/Python projects (#266) |
| 128 | + |
| 129 | +## 0.4.3 (2026-04-12) |
| 130 | + |
| 131 | +- Fix: JS/TS relative imports now resolve to full-path node IDs — previously all `imports_from` edges were silently dropped on large TypeScript codebases (#256) |
| 132 | +- Fix: Python relative imports (`from .foo import bar`) now resolve correctly to full-path node IDs (#256) |
| 133 | +- Fix: `watch --rebuild_code` now merges fresh AST with existing semantic nodes from docs/papers instead of overwriting them (#253) |
| 134 | +- Fix: Windows hooks now fall back to `python` if `python3` is not found; exits cleanly if neither has graphify installed (#244) |
| 135 | +- Fix: `surprising_connections` / `suggest_questions` no longer crash with `KeyError` on stale `_src`/`_tgt` edge hints after node merges (#226) |
| 136 | +- Add: `.vue` and `.svelte` files now recognized as code and included in extraction (#254) |
| 137 | + |
| 138 | +## 0.4.2 (2026-04-11) |
| 139 | + |
| 140 | +- Fix: same-basename files in different directories produced colliding node IDs — now uses full path (#211) |
| 141 | +- Fix: edges using `from`/`to` keys instead of `source`/`target` were silently dropped (#216) |
| 142 | +- Fix: empty graphs (no edges) crashed `to_html` with `ZeroDivisionError` (#217) |
| 143 | +- Fix: post-commit hook skipped `.tsx`, `.jsx`, and other valid code extensions due to stale allowlist (#222) |
| 144 | +- Fix: NetworkX ≤3.1 serialises edges as `links` — now accepted alongside `edges` (#212) |
| 145 | +- Fix: version warning fired during `install`/`uninstall` and duplicated on shared paths (#220) |
| 146 | +- Fix: all file IO now uses `encoding="utf-8"` — prevents crashes on Windows with CJK or emoji labels; hook writes use `newline="\n"` to prevent CRLF shebang breakage (#204) |
| 147 | +- Fix: Obsidian export — node labels ending in `.md` produced `.md.md` filenames; `GRAPH_REPORT.md` now links to community hub files so vault stays in one connected component (#221) |
| 148 | + |
5 | 149 | ## 0.4.1 (2026-04-10) |
6 | 150 |
|
7 | 151 | - Fix: `collect_files()` in `extract.py` now respects `.graphifyignore` — previously ignored patterns, causing thousands of unwanted files (e.g. `node_modules/`) to be scanned (#188) |
|
0 commit comments