<!doctype html>
<html lang="en" class="no-js">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<link rel="prev" href="..">
<link rel="next" href="../use_cases/">
<link rel="icon" href="../assets/images/favicon.png">
<meta name="generator" content="mkdocs-1.6.1, mkdocs-material-9.7.1">
<title>Installation - CodeGraphContext</title>
<link rel="stylesheet" href="../assets/stylesheets/main.484c7ddc.min.css">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,300i,400,400i,700,700i%7CRoboto+Mono:400,400i,700,700i&display=fallback">
<style>:root{--md-text-font:"Roboto";--md-code-font:"Roboto Mono"}</style>
<script>__md_scope=new URL("..",location),__md_hash=e=>[...e].reduce(((e,_)=>(e<<5)-e+_.charCodeAt(0)),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
</head>
<body dir="ltr">
<input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
<input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
<label class="md-overlay" for="__drawer"></label>
<div data-md-component="skip">
<a href="#installation-guide" class="md-skip">
Skip to content
</a>
</div>
<div data-md-component="announce">
</div>
<header class="md-header md-header--shadow" data-md-component="header">
<nav class="md-header__inner md-grid" aria-label="Header">
<a href=".." title="CodeGraphContext" class="md-header__button md-logo" aria-label="CodeGraphContext" data-md-component="logo">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54"/></svg>
</a>
<label class="md-header__button md-icon" for="__drawer">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3zm0 5h18v2H3zm0 5h18v2H3z"/></svg>
</label>
<div class="md-header__title" data-md-component="header-title">
<div class="md-header__ellipsis">
<div class="md-header__topic">
<span class="md-ellipsis">
CodeGraphContext
</span>
</div>
<div class="md-header__topic" data-md-component="header-topic">
<span class="md-ellipsis">
Installation
</span>
</div>
</div>
</div>
<script>var palette=__md_get("__palette");if(palette&&palette.color){if("(prefers-color-scheme)"===palette.color.media){var media=matchMedia("(prefers-color-scheme: light)"),input=document.querySelector(media.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']");palette.color.media=input.getAttribute("data-md-color-media"),palette.color.scheme=input.getAttribute("data-md-color-scheme"),palette.color.primary=input.getAttribute("data-md-color-primary"),palette.color.accent=input.getAttribute("data-md-color-accent")}for(var[key,value]of Object.entries(palette.color))document.body.setAttribute("data-md-color-"+key,value)}</script>
<label class="md-header__button md-icon" for="__search">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
</label>
<div class="md-search" data-md-component="search" role="dialog">
<label class="md-search__overlay" for="__search"></label>
<div class="md-search__inner" role="search">
<form class="md-search__form" name="search">
<input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required>
<label class="md-search__icon md-icon" for="__search">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11z"/></svg>
</label>
<nav class="md-search__options" aria-label="Search">
<button type="reset" class="md-search__icon md-icon" title="Clear" aria-label="Clear" tabindex="-1">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>
</button>
</nav>
</form>
<div class="md-search__output">
<div class="md-search__scrollwrap" tabindex="0" data-md-scrollfix>
<div class="md-search-result" data-md-component="search-result">
<div class="md-search-result__meta">
Initializing search
</div>
<ol class="md-search-result__list" role="presentation"></ol>
</div>
</div>
</div>
</div>
</div>
</nav>
</header>
<div class="md-container" data-md-component="container">
<main class="md-main" data-md-component="main">
<div class="md-main__inner md-grid">
<div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
<label class="md-nav__title" for="__drawer">
<a href=".." title="CodeGraphContext" class="md-nav__button md-logo" aria-label="CodeGraphContext" data-md-component="logo">
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54"/></svg>
</a>
CodeGraphContext
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href=".." class="md-nav__link">
<span class="md-ellipsis">
Home
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--active">
<input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
<label class="md-nav__link md-nav__link--active" for="__toc">
<span class="md-ellipsis">
Installation
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<a href="./" class="md-nav__link md-nav__link--active">
<span class="md-ellipsis">
Installation
</span>
</a>
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
<label class="md-nav__title" for="__toc">
<span class="md-nav__icon md-icon"></span>
Table of contents
</label>
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#installation-guide" class="md-nav__link">
<span class="md-ellipsis">
🧩 Installation Guide
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#understanding-codegraphcontext-modes" class="md-nav__link">
<span class="md-ellipsis">
📋 Understanding CodeGraphContext Modes
</span>
</a>
<nav class="md-nav" aria-label="📋 Understanding CodeGraphContext Modes">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#mode-1-cli-toolkit-standalone" class="md-nav__link">
<span class="md-ellipsis">
🛠️ Mode 1: CLI Toolkit (Standalone)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#mode-2-mcp-server-ai-powered" class="md-nav__link">
<span class="md-ellipsis">
🤖 Mode 2: MCP Server (AI-Powered)
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#prerequisites" class="md-nav__link">
<span class="md-ellipsis">
⚙️ Prerequisites
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#installation" class="md-nav__link">
<span class="md-ellipsis">
🚀 Installation
</span>
</a>
<nav class="md-nav" aria-label="🚀 Installation">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#step-1-install-from-pypi" class="md-nav__link">
<span class="md-ellipsis">
Step 1: Install from PyPI
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#step-2-database-setup" class="md-nav__link">
<span class="md-ellipsis">
Step 2: Database Setup
</span>
</a>
<nav class="md-nav" aria-label="Step 2: Database Setup">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#option-a-falkordb-lite-default-recommended" class="md-nav__link">
<span class="md-ellipsis">
Option A: FalkorDB Lite (Default - Recommended)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#option-b-neo4j-alternative" class="md-nav__link">
<span class="md-ellipsis">
Option B: Neo4j (Alternative)
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#mode-specific-setup" class="md-nav__link">
<span class="md-ellipsis">
🎯 Mode-Specific Setup
</span>
</a>
<nav class="md-nav" aria-label="🎯 Mode-Specific Setup">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#for-cli-toolkit-mode-mode-1" class="md-nav__link">
<span class="md-ellipsis">
For CLI Toolkit Mode (Mode 1)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#for-mcp-server-mode-mode-2" class="md-nav__link">
<span class="md-ellipsis">
For MCP Server Mode (Mode 2)
</span>
</a>
<nav class="md-nav" aria-label="For MCP Server Mode (Mode 2)">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#step-1-run-mcp-setup-wizard" class="md-nav__link">
<span class="md-ellipsis">
Step 1: Run MCP Setup Wizard
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#step-2-start-the-mcp-server" class="md-nav__link">
<span class="md-ellipsis">
Step 2: Start the MCP Server
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#manual-configuration-optional" class="md-nav__link">
<span class="md-ellipsis">
Manual Configuration (Optional)
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#quick-start-examples" class="md-nav__link">
<span class="md-ellipsis">
🧭 Quick Start Examples
</span>
</a>
<nav class="md-nav" aria-label="🧭 Quick Start Examples">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#cli-toolkit-workflow" class="md-nav__link">
<span class="md-ellipsis">
CLI Toolkit Workflow
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#mcp-server-workflow" class="md-nav__link">
<span class="md-ellipsis">
MCP Server Workflow
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#database-configuration-details" class="md-nav__link">
<span class="md-ellipsis">
🔧 Database Configuration Details
</span>
</a>
<nav class="md-nav" aria-label="🔧 Database Configuration Details">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#falkordb-lite-default" class="md-nav__link">
<span class="md-ellipsis">
FalkorDB Lite (Default)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#neo4j" class="md-nav__link">
<span class="md-ellipsis">
Neo4j
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#next-steps" class="md-nav__link">
<span class="md-ellipsis">
📚 Next Steps
</span>
</a>
<nav class="md-nav" aria-label="📚 Next Steps">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#for-cli-users" class="md-nav__link">
<span class="md-ellipsis">
For CLI Users
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#for-mcp-users" class="md-nav__link">
<span class="md-ellipsis">
For MCP Users
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#troubleshooting" class="md-nav__link">
<span class="md-ellipsis">
🆘 Troubleshooting
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../use_cases/" class="md-nav__link">
<span class="md-ellipsis">
Use Cases
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../architecture/" class="md-nav__link">
<span class="md-ellipsis">
Architecture
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../cli/" class="md-nav__link">
<span class="md-ellipsis">
CLI Reference
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../watching/" class="md-nav__link">
<span class="md-ellipsis">
Live Watching
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../server/" class="md-nav__link">
<span class="md-ellipsis">
Server
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../core/" class="md-nav__link">
<span class="md-ellipsis">
Core Concepts
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../tools/" class="md-nav__link">
<span class="md-ellipsis">
Tools
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../cookbook/" class="md-nav__link">
<span class="md-ellipsis">
Cookbook
</span>
</a>
</li>
<li class="md-nav__item md-nav__item--nested">
<input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_11" >
<label class="md-nav__link" for="__nav_11" id="__nav_11_label" tabindex="0">
<span class="md-ellipsis">
Contributing
</span>
<span class="md-nav__icon md-icon"></span>
</label>
<nav class="md-nav" data-md-level="1" aria-labelledby="__nav_11_label" aria-expanded="false">
<label class="md-nav__title" for="__nav_11">
<span class="md-nav__icon md-icon"></span>
Contributing
</label>
<ul class="md-nav__list" data-md-scrollfix>
<li class="md-nav__item">
<a href="../contributing/" class="md-nav__link">
<span class="md-ellipsis">
Overview
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../contributing_languages/" class="md-nav__link">
<span class="md-ellipsis">
Adding New Languages
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="../troubleshooting/" class="md-nav__link">
<span class="md-ellipsis">
Troubleshooting
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../future_work/" class="md-nav__link">
<span class="md-ellipsis">
Future Work
</span>
</a>
</li>
<li class="md-nav__item">
<a href="../license/" class="md-nav__link">
<span class="md-ellipsis">
License
</span>
</a>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
<div class="md-sidebar__scrollwrap">
<div class="md-sidebar__inner">
<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
<label class="md-nav__title" for="__toc">
<span class="md-nav__icon md-icon"></span>
Table of contents
</label>
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
<li class="md-nav__item">
<a href="#installation-guide" class="md-nav__link">
<span class="md-ellipsis">
🧩 Installation Guide
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#understanding-codegraphcontext-modes" class="md-nav__link">
<span class="md-ellipsis">
📋 Understanding CodeGraphContext Modes
</span>
</a>
<nav class="md-nav" aria-label="📋 Understanding CodeGraphContext Modes">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#mode-1-cli-toolkit-standalone" class="md-nav__link">
<span class="md-ellipsis">
🛠️ Mode 1: CLI Toolkit (Standalone)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#mode-2-mcp-server-ai-powered" class="md-nav__link">
<span class="md-ellipsis">
🤖 Mode 2: MCP Server (AI-Powered)
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#prerequisites" class="md-nav__link">
<span class="md-ellipsis">
⚙️ Prerequisites
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#installation" class="md-nav__link">
<span class="md-ellipsis">
🚀 Installation
</span>
</a>
<nav class="md-nav" aria-label="🚀 Installation">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#step-1-install-from-pypi" class="md-nav__link">
<span class="md-ellipsis">
Step 1: Install from PyPI
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#step-2-database-setup" class="md-nav__link">
<span class="md-ellipsis">
Step 2: Database Setup
</span>
</a>
<nav class="md-nav" aria-label="Step 2: Database Setup">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#option-a-falkordb-lite-default-recommended" class="md-nav__link">
<span class="md-ellipsis">
Option A: FalkorDB Lite (Default - Recommended)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#option-b-neo4j-alternative" class="md-nav__link">
<span class="md-ellipsis">
Option B: Neo4j (Alternative)
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#mode-specific-setup" class="md-nav__link">
<span class="md-ellipsis">
🎯 Mode-Specific Setup
</span>
</a>
<nav class="md-nav" aria-label="🎯 Mode-Specific Setup">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#for-cli-toolkit-mode-mode-1" class="md-nav__link">
<span class="md-ellipsis">
For CLI Toolkit Mode (Mode 1)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#for-mcp-server-mode-mode-2" class="md-nav__link">
<span class="md-ellipsis">
For MCP Server Mode (Mode 2)
</span>
</a>
<nav class="md-nav" aria-label="For MCP Server Mode (Mode 2)">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#step-1-run-mcp-setup-wizard" class="md-nav__link">
<span class="md-ellipsis">
Step 1: Run MCP Setup Wizard
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#step-2-start-the-mcp-server" class="md-nav__link">
<span class="md-ellipsis">
Step 2: Start the MCP Server
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#manual-configuration-optional" class="md-nav__link">
<span class="md-ellipsis">
Manual Configuration (Optional)
</span>
</a>
</li>
</ul>
</nav>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#quick-start-examples" class="md-nav__link">
<span class="md-ellipsis">
🧭 Quick Start Examples
</span>
</a>
<nav class="md-nav" aria-label="🧭 Quick Start Examples">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#cli-toolkit-workflow" class="md-nav__link">
<span class="md-ellipsis">
CLI Toolkit Workflow
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#mcp-server-workflow" class="md-nav__link">
<span class="md-ellipsis">
MCP Server Workflow
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#database-configuration-details" class="md-nav__link">
<span class="md-ellipsis">
🔧 Database Configuration Details
</span>
</a>
<nav class="md-nav" aria-label="🔧 Database Configuration Details">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#falkordb-lite-default" class="md-nav__link">
<span class="md-ellipsis">
FalkorDB Lite (Default)
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#neo4j" class="md-nav__link">
<span class="md-ellipsis">
Neo4j
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#next-steps" class="md-nav__link">
<span class="md-ellipsis">
📚 Next Steps
</span>
</a>
<nav class="md-nav" aria-label="📚 Next Steps">
<ul class="md-nav__list">
<li class="md-nav__item">
<a href="#for-cli-users" class="md-nav__link">
<span class="md-ellipsis">
For CLI Users
</span>
</a>
</li>
<li class="md-nav__item">
<a href="#for-mcp-users" class="md-nav__link">
<span class="md-ellipsis">
For MCP Users
</span>
</a>
</li>
</ul>
</nav>
</li>
<li class="md-nav__item">
<a href="#troubleshooting" class="md-nav__link">
<span class="md-ellipsis">
🆘 Troubleshooting
</span>
</a>
</li>
</ul>
</nav>
</div>
</div>
</div>
<div class="md-content" data-md-component="content">
<article class="md-content__inner md-typeset">
<h1>Installation</h1>
<h2 id="installation-guide">🧩 Installation Guide</h2>
<p>Welcome to <strong>CodeGraphContext</strong>! This guide provides a clear and seamless path to installing and configuring the tool.</p>
<h2 id="understanding-codegraphcontext-modes">📋 Understanding CodeGraphContext Modes</h2>
<p>CodeGraphContext operates in <strong>two modes</strong>, and you can use either or both:</p>
<h3 id="mode-1-cli-toolkit-standalone">🛠️ Mode 1: CLI Toolkit (Standalone)</h3>
<p>Use CodeGraphContext as a <strong>powerful command-line toolkit</strong> for code analysis:
- Index and analyze codebases directly from your terminal
- Query code relationships, find dead code, analyze complexity
- Visualize code graphs and dependencies
- Perfect for developers who want direct control via CLI commands</p>
<h3 id="mode-2-mcp-server-ai-powered">🤖 Mode 2: MCP Server (AI-Powered)</h3>
<p>Use CodeGraphContext as an <strong>MCP server</strong> for AI assistants:
- Connect to AI IDEs (VS Code, Cursor, Windsurf, Claude, etc.)
- Let AI agents query your codebase using natural language
- Automatic code understanding and relationship analysis
- Perfect for AI-assisted development workflows</p>
<p><strong>You can use both modes!</strong> Install once, then use CLI commands directly OR connect to your AI assistant.</p>
<hr />
<h2 id="prerequisites">⚙️ Prerequisites</h2>
<p>Ensure the following are installed before you begin:</p>
<ul>
<li><strong>Python</strong>: Version 3.10 or higher (3.12+ recommended for FalkorDB Lite support)</li>
<li><strong>AI Assistant</strong> (optional): An MCP-compatible tool (e.g., VS Code, Cursor, Claude, Gemini CLI) if you plan to use Mode 2</li>
</ul>
<hr />
<h2 id="installation">🚀 Installation</h2>
<h3 id="step-1-install-from-pypi">Step 1: Install from PyPI</h3>
<p>Install the <code>codegraphcontext</code> package using pip:</p>
<pre><code class="language-bash">pip install codegraphcontext
</code></pre>
<h3 id="step-2-database-setup">Step 2: Database Setup</h3>
<p>CodeGraphContext uses a graph database to store code relationships. You have two options:</p>
<h4 id="option-a-falkordb-lite-default-recommended">Option A: FalkorDB Lite (Default - Recommended)</h4>
<ul>
<li><strong>Automatic</strong> on Unix/Linux/macOS/WSL with Python 3.12+</li>
<li><strong>No configuration needed</strong> - works out of the box</li>
<li>Lightweight, in-memory, perfect for most use cases</li>
</ul>
<p>If you're on Unix/Linux/macOS/WSL with Python 3.12+, <strong>you're done!</strong> Skip to Step 3.</p>
<h4 id="option-b-neo4j-alternative">Option B: Neo4j (Alternative)</h4>
<ul>
<li>Available on <strong>all platforms</strong> (Windows, Linux, macOS)</li>
<li>Required if you're on Windows without WSL or prefer Neo4j</li>
<li>Can be installed via Docker, native installation, or cloud (AuraDB)</li>
</ul>
<p>To set up Neo4j, run:</p>
<pre><code class="language-bash">cgc neo4j setup
</code></pre>
<p>The wizard will guide you through:
- <strong>Docker</strong> (recommended): Automatically sets up a local Neo4j container
- <strong>Native Installation</strong>: Installs Neo4j directly on Debian-based systems or macOS
- <strong>Hosted/AuraDB</strong>: Connect to a remote Neo4j instance
- <strong>Existing Instance</strong>: Use your own Neo4j server</p>
<hr />
<h2 id="mode-specific-setup">🎯 Mode-Specific Setup</h2>
<h3 id="for-cli-toolkit-mode-mode-1">For CLI Toolkit Mode (Mode 1)</h3>
<p>You're ready to go! Start using CLI commands:</p>
<pre><code class="language-bash"># Index your current directory
cgc index .
# List indexed repositories
cgc list
# Analyze code relationships
cgc analyze callers my_function
# Find complex functions
cgc analyze complexity --threshold 10
# See all available commands
cgc --help
</code></pre>
<p><strong>See the <a href="../cli/">CLI Reference</a> for all available commands.</strong></p>
<hr />
<h3 id="for-mcp-server-mode-mode-2">For MCP Server Mode (Mode 2)</h3>
<p>Configure your AI assistant to connect to CodeGraphContext:</p>
<h4 id="step-1-run-mcp-setup-wizard">Step 1: Run MCP Setup Wizard</h4>
<pre><code class="language-bash">cgc mcp setup
</code></pre>
<p>The wizard will:
- Detect your installed AI tools (VS Code, Cursor, Claude, etc.)
- Automatically configure the selected tool
- Generate <code>mcp.json</code> configuration file
- Store credentials securely in <code>~/.codegraphcontext/.env</code></p>
<p><strong>Supported AI Tools:</strong>
- VS Code
- Cursor
- Windsurf
- Claude Desktop
- Gemini CLI
- ChatGPT Codex
- Cline
- RooCode
- Amazon Q Developer</p>
<h4 id="step-2-start-the-mcp-server">Step 2: Start the MCP Server</h4>
<pre><code class="language-bash">cgc mcp start
</code></pre>
<p>Your MCP server is now running and ready to receive requests from your AI assistant!</p>
<h4 id="manual-configuration-optional">Manual Configuration (Optional)</h4>
<p>If you prefer to configure manually or your tool isn't auto-detected, add this to your tool's settings file:</p>
<pre><code class="language-json">{
"mcpServers": {
"CodeGraphContext": {
"command": "cgc",
"args": ["mcp", "start"],
"env": {
"NEO4J_URI": "bolt://localhost:7687",
"NEO4J_USERNAME": "neo4j",
"NEO4J_PASSWORD": "your-password"
}
}
}
}
</code></pre>
<p><strong>Note:</strong> If using FalkorDB Lite (default), you don't need to set NEO4J_* environment variables.</p>
<hr />
<h2 id="quick-start-examples">🧭 Quick Start Examples</h2>
<h3 id="cli-toolkit-workflow">CLI Toolkit Workflow</h3>
<pre><code class="language-bash"># Install
pip install codegraphcontext
# Index a project
cgc index /path/to/my-project
# Find all callers of a function
cgc analyze callers process_payment
# Find dead code
cgc analyze dead-code
# Check database stats
cgc stats
</code></pre>
<h3 id="mcp-server-workflow">MCP Server Workflow</h3>
<pre><code class="language-bash"># Install
pip install codegraphcontext
# Configure your AI assistant
cgc mcp setup
# Start the server
cgc mcp start
# Now use natural language in your AI assistant:
# "Index the code in /path/to/my-project"
# "Find all functions that call process_payment"
# "Show me the class hierarchy for UserController"
</code></pre>
<hr />
<h2 id="database-configuration-details">🔧 Database Configuration Details</h2>
<h3 id="falkordb-lite-default">FalkorDB Lite (Default)</h3>
<ul>
<li><strong>Platform</strong>: Unix/Linux/macOS/WSL</li>
<li><strong>Python</strong>: 3.12+ required</li>
<li><strong>Setup</strong>: Automatic, no configuration needed</li>
<li><strong>Storage</strong>: In-memory</li>
<li><strong>Best for</strong>: Most use cases, quick testing, development</li>
</ul>
<h3 id="neo4j">Neo4j</h3>
<ul>
<li><strong>Platform</strong>: All (Windows, Linux, macOS)</li>
<li><strong>Python</strong>: 3.10+ supported</li>
<li><strong>Setup</strong>: Via <code>cgc neo4j setup</code> wizard</li>
<li><strong>Storage</strong>: Persistent disk storage</li>
<li><strong>Best for</strong>: Windows users, production deployments, large codebases</li>
</ul>
<hr />
<h2 id="next-steps">📚 Next Steps</h2>
<h3 id="for-cli-users">For CLI Users</h3>
<ul>
<li>Explore the <a href="../cli/">CLI Reference</a> for all available commands</li>
<li>Check out the <a href="../cookbook/">Cookbook</a> for common analysis patterns</li>
<li>Learn about <a href="../core/">Code Analysis</a> capabilities</li>
</ul>
<h3 id="for-mcp-users">For MCP Users</h3>
<ul>
<li>See <a href="../tools/">MCP Tools Documentation</a> for available AI tools</li>
<li>Review <a href="../#natural-language-interaction-examples">Natural Language Examples</a></li>
<li>Explore the <a href="../use_cases/">Use Cases</a> guide</li>
</ul>
<hr />
<h2 id="troubleshooting">🆘 Troubleshooting</h2>
<p>If you encounter issues, see our <a href="../troubleshooting/">Troubleshooting Guide</a> for common problems and solutions.</p>
<p><strong>Common Issues:</strong>
- <strong>"cgc: command not found"</strong>: Run the PATH fix script (see main README)
- <strong>Database connection errors</strong>: Ensure Neo4j is running (if using Neo4j) or Python 3.12+ (if using FalkorDB)
- <strong>MCP server won't start</strong>: Check that your AI assistant is properly configured</p>
<hr />
<p>With <strong>CodeGraphContext</strong> installed, you're ready to explore powerful code analysis capabilities! Happy coding ✨!</p>
</article>
</div>
<script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
</div>
</main>
<footer class="md-footer">
<div class="md-footer-meta md-typeset">
<div class="md-footer-meta__inner md-grid">
<div class="md-copyright">
Made with
<a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
Material for MkDocs
</a>
</div>
</div>
</div>
</footer>
</div>
<div class="md-dialog" data-md-component="dialog">
<div class="md-dialog__inner md-typeset"></div>
</div>
<script id="__config" type="application/json">{"annotate": null, "base": "..", "features": [], "search": "../assets/javascripts/workers/search.2c215733.min.js", "tags": null, "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version": "Select version"}, "version": null}</script>
<script src="../assets/javascripts/bundle.79ae519e.min.js"></script>
</body>
</html>