Multi-dimensional code complexity analyzer
Project description
semantic-complexity (Python)
Multi-dimensional code complexity analyzer for Python.
Installation
pip install semantic-complexity
uv를 통한 설치
# 글로벌 도구로 설치
uv tool install semantic-complexity
# 또는 일회성 실행
uvx semantic-complexity path/to/file.py
MCP 서버 설치
Claude Code에서 MCP 서버로 사용하려면:
# MCP 서버 추가 (Python 버전)
claude mcp add sc-py "uvx --from semantic-complexity semantic-complexity-py-mcp"
기존 MCP 업데이트/재설치
# 1. 기존 MCP 삭제
claude mcp remove sc-py
# 2. 캐시 정리 (최신 버전 반영)
uv cache clean semantic-complexity --force
# 3. 재설치
claude mcp add sc-py "uvx --from semantic-complexity semantic-complexity-py-mcp"
# 설치 확인
claude mcp list
Usage
CLI
# Analyze a file
semantic-complexity path/to/file.py
# Analyze a directory
semantic-complexity path/to/project/
# Output as Markdown report
semantic-complexity path/to/project/ -f markdown -o report.md
# Filter by threshold
semantic-complexity path/to/project/ --threshold 20
Python API
from semantic_complexity import analyze_source, analyze_functions
# Analyze source code
result = analyze_source("""
def complex_function(x):
if x > 0:
for i in range(x):
if i % 2 == 0:
print(i)
""")
print(f"Weighted complexity: {result.weighted}")
print(f"Control: {result.control}")
print(f"Nesting: {result.nesting}")
print(f"Contributions: {result.contributions}")
# Analyze functions individually
functions = analyze_functions(source)
for fn in functions:
print(f"{fn.name}: McCabe={fn.cyclomatic}, Dimensional={fn.dimensional.weighted}")
Domains
| Domain | Weight | Description |
|---|---|---|
| Control (C) | 1.0 | Cyclomatic complexity (branches, loops) |
| Nesting (N) | 1.5 | Depth penalty |
| State (S) | 2.0 | State mutations and transitions |
| Async (A) | 2.5 | Async/await, coroutines |
| Coupling (Λ) | 3.0 | Hidden dependencies, side effects |
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file semantic_complexity-0.0.21.tar.gz.
File metadata
- Download URL: semantic_complexity-0.0.21.tar.gz
- Upload date:
- Size: 190.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eb1b010b1d7bbb7b2acf66ca2a15007c389f3997fa61b848720d848bd7d5a99a
|
|
| MD5 |
ecc3574867bdd3bcd6b39bf1e72af6cf
|
|
| BLAKE2b-256 |
f167a6ca626d39a360718bad97cc4f7a2dfc5290b2fb85c55f42356258513808
|
Provenance
The following attestation bundles were made for semantic_complexity-0.0.21.tar.gz:
Publisher:
publish-pypi.yml on yscha88/semantic-complexity
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
semantic_complexity-0.0.21.tar.gz -
Subject digest:
eb1b010b1d7bbb7b2acf66ca2a15007c389f3997fa61b848720d848bd7d5a99a - Sigstore transparency entry: 788675192
- Sigstore integration time:
-
Permalink:
yscha88/semantic-complexity@cb57160c0f05a23547f7ed2df5bdb9efd905d4e8 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/yscha88
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@cb57160c0f05a23547f7ed2df5bdb9efd905d4e8 -
Trigger Event:
push
-
Statement type:
File details
Details for the file semantic_complexity-0.0.21-py3-none-any.whl.
File metadata
- Download URL: semantic_complexity-0.0.21-py3-none-any.whl
- Upload date:
- Size: 108.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
434599139abfba2c62246a82e19f32dc3a3b29be55750ec4cfa7f70c8d5bde4b
|
|
| MD5 |
e2009a13836dd574b6fdfd12f3eb7e93
|
|
| BLAKE2b-256 |
8dd3641a1e13e69a640e1def655e25a3ece2b0d5d618742c9cd06f89eadda359
|
Provenance
The following attestation bundles were made for semantic_complexity-0.0.21-py3-none-any.whl:
Publisher:
publish-pypi.yml on yscha88/semantic-complexity
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
semantic_complexity-0.0.21-py3-none-any.whl -
Subject digest:
434599139abfba2c62246a82e19f32dc3a3b29be55750ec4cfa7f70c8d5bde4b - Sigstore transparency entry: 788675228
- Sigstore integration time:
-
Permalink:
yscha88/semantic-complexity@cb57160c0f05a23547f7ed2df5bdb9efd905d4e8 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/yscha88
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@cb57160c0f05a23547f7ed2df5bdb9efd905d4e8 -
Trigger Event:
push
-
Statement type: